الفرق بين المراجعتين لصفحة: «Ruby/Module/module function»
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: التابع <code>module_function</code> الخاص بالصنف <code>Module</code> في روبي}}</noinclude> تصنيف: Ruby [...' |
لا ملخص تعديل |
||
سطر 3: | سطر 3: | ||
[[تصنيف: Ruby Method]] | [[تصنيف: Ruby Method]] | ||
[[تصنيف: Ruby Module]] | [[تصنيف: Ruby Module]] | ||
ينشئ التابع <code>module_function</code> دوال وحدة (module functions) للتابع المعطى. يمكن استدعاء هذه الدوال مع الوحدة | ينشئ التابع <code>module_function</code> دوال وحدة (module functions) للتابع المعطى. يمكن استدعاء هذه الدوال مع الوحدة كمُستقبِلات (receiver)، كما يمكن أن تصير متاحة كتوابع نسخة (instance methods) للأصناف التي تُمزج (mix) في الوحدة. دوال النوع <code>[[Ruby/Module|Module]]</code> هي نسخ من الدالة الأصلية، وبالتالي يمكن تغييرها بشكل مستقل. | ||
توابع النسخة (instance-method) ستُجعل خاصة. وإذا تم استدعاء التابع <code>module_function</code> دون وسائط، ستصبح التوابع المعرفة لاحقاً دوال وحدة (module functions). | |||
تُحوّل الوسائط النصية إلى رموز. | |||
==البنية العامة== | ==البنية العامة== | ||
<syntaxhighlight lang="ruby">module_function(symbol, ...) → self | <syntaxhighlight lang="ruby">module_function(symbol, ...) → self | ||
سطر 9: | سطر 13: | ||
==المعاملات== | ==المعاملات== | ||
===<code>symbol</code>=== | ===<code>symbol</code>=== | ||
رمز. | |||
===<code>string</code>=== | ===<code>string</code>=== | ||
سلسلة نصية. | |||
==القيمة المُعادة== | ==القيمة المُعادة== | ||
يعيد التابع <code>module_function</code> الكائن الذي استُدعي معه. | |||
==أمثلة== | ==أمثلة== | ||
سطر 42: | سطر 46: | ||
c.call_one #=> "This is the new one"</syntaxhighlight> | c.call_one #=> "This is the new one"</syntaxhighlight> | ||
==انظر أيضا== | ==انظر أيضا== | ||
* التابع <code>[[Ruby/Module/module_exec|module_exec]]</code>: يقيّم الكتلة الممررة في سياق الصنف/الوحدة | * التابع <code>[[Ruby/Module/module_exec|module_exec]]</code>: يقيّم الكتلة الممررة في سياق الصنف/الوحدة. | ||
* التابع <code>[[Ruby/Module/name|name]]</code>: يعيد اسم الوحدة | * التابع <code>[[Ruby/Module/name|name]]</code>: يعيد اسم الوحدة. | ||
==مصادر== | ==مصادر== | ||
*[http://ruby-doc.org/core-2.5.1/Module.html#method-i-module_function قسم التابع module_function في الصنف Module في توثيق روبي الرسمي.] | *[http://ruby-doc.org/core-2.5.1/Module.html#method-i-module_function قسم التابع module_function في الصنف Module في توثيق روبي الرسمي.] |
مراجعة 01:52، 27 أكتوبر 2018
ينشئ التابع module_function
دوال وحدة (module functions) للتابع المعطى. يمكن استدعاء هذه الدوال مع الوحدة كمُستقبِلات (receiver)، كما يمكن أن تصير متاحة كتوابع نسخة (instance methods) للأصناف التي تُمزج (mix) في الوحدة. دوال النوع Module
هي نسخ من الدالة الأصلية، وبالتالي يمكن تغييرها بشكل مستقل.
توابع النسخة (instance-method) ستُجعل خاصة. وإذا تم استدعاء التابع module_function
دون وسائط، ستصبح التوابع المعرفة لاحقاً دوال وحدة (module functions).
تُحوّل الوسائط النصية إلى رموز.
البنية العامة
module_function(symbol, ...) → self
module_function(string, ...) → self
المعاملات
symbol
رمز.
string
سلسلة نصية.
القيمة المُعادة
يعيد التابع module_function
الكائن الذي استُدعي معه.
أمثلة
مثال على استخدام التابع module_function
:
module Mod
def one
"This is one"
end
module_function :one
end
class Cls
include Mod
def call_one
one
end
end
Mod.one #=> "This is one"
c = Cls.new
c.call_one #=> "This is one"
module Mod
def one
"This is the new one"
end
end
Mod.one #=> "This is one"
c.call_one #=> "This is the new one"
انظر أيضا
- التابع
module_exec
: يقيّم الكتلة الممررة في سياق الصنف/الوحدة. - التابع
name
: يعيد اسم الوحدة.