الفرق بين المراجعتين لصفحة: «PHP/func get arg»
لا ملخص تعديل |
|||
سطر 1: | سطر 1: | ||
(PHP 4, PHP 5, PHP 7) | (PHP 4, PHP 5, PHP 7) | ||
تُعيد الدالّة func_get_arg() وسيطًا من قائمة الوسطاء. | تُعيد الدالّة <code>func_get_arg()</code> وسيطًا من قائمة الوسطاء. | ||
== الوصف == | == الوصف == | ||
----<syntaxhighlight lang="php"> | ----<syntaxhighlight lang="php"> | ||
mixed func_get_arg ( int $arg_num ) | mixed func_get_arg ( int $arg_num ) | ||
</syntaxhighlight>تحصل الدالّة func_get_arg() على وسيط من قائمة وسطاء الدّالة المعرّفة من قبل المستخدم. | </syntaxhighlight>تحصل الدالّة <code>func_get_arg()</code> على وسيط من قائمة وسطاء الدّالة المعرّفة من قبل المستخدم. | ||
من الممكن أن تُستخدم هذه الدّالة بالتزامن مع الدالّة func_get_args() | من الممكن أن تُستخدم هذه الدّالة بالتزامن مع الدالّة <code>func_get_args()</code> والدالّة <code>[[PHP/func num args|func_num_args()]]</code> للسماح للدالات المعرّفة من قبل المستخدم بقبول قوائم وسطاء متغيرة الطول. | ||
== المعاملات == | == المعاملات == | ||
---- | ---- | ||
=== arg_num === | === <code>arg_num</code> === | ||
فهرس الوسيط المُراد الحصول على قيمته. لاحظ أنَّه تُعَدّ وسائط الدّالة بدءًا من الصفر. | فهرس الوسيط المُراد الحصول على قيمته. لاحظ أنَّه تُعَدّ وسائط الدّالة بدءًا من الصفر. | ||
== القيم المعادة == | == القيم المعادة == | ||
----تُعيد الدالّة func_get_arg() الوسيط | ----تُعيد الدالّة <code>func_get_arg()</code> الوسيط المحدّد، أو تُعيد <code>FALSE</code> في حال حدوث الخطأ. | ||
== سجل التغييرات == | == سجل التغييرات == | ||
---- | ---- | ||
{| class="wikitable" | {| class="wikitable" | ||
!الإصدار | |||
!الوصف | |||
|- | |- | ||
|5.3.0 | |5.3.0 | ||
سطر 29: | سطر 29: | ||
|- | |- | ||
|5.3.0 | |5.3.0 | ||
|إذا استُدعيت هذه الدالّة من النطاق الخارجي لملف مُضمَّن من خلال | |إذا استُدعيت هذه الدالّة من النطاق الخارجي لملف مُضمَّن من خلال استدعاء <code>[[PHP/include|include]]</code> أو <code>[[PHP/require|require]]</code> من داخل دالّة في الملف المستدعي، فستولد تحذيرًا وتُعيد <code>FALSE</code>. | ||
|} | |} | ||
== الأخطاء والاستثناءات == | == الأخطاء والاستثناءات == | ||
----تولّد الدّالة func_get_arg() تحذيرًا إذا استدعيت من خارج دالة معرّفة من قبل المستخدم، أو إذا كانت | ----تولّد الدّالة <code>func_get_arg()</code> تحذيرًا إذا استدعيت من خارج دالة معرّفة من قبل المستخدم، أو إذا كانت قيمة <code>arg_num</code> أكبر من عدد الوسطاء الممرّرة. | ||
== أمثلة == | == أمثلة == | ||
----المثال 1: مثال عن استخدام الدالّة func_get_arg()<syntaxhighlight lang="php"> | ----المثال 1: مثال عن استخدام الدالّة <code>func_get_arg()</code><syntaxhighlight lang="php"> | ||
<?php | <?php | ||
function foo() | function foo() | ||
سطر 49: | سطر 49: | ||
foo(1, 2, 3); | foo(1, 2, 3); | ||
?> | ?> | ||
</syntaxhighlight>سينتج المثال السابق الناتج الآتي:<syntaxhighlight lang=" | </syntaxhighlight>سينتج المثال السابق الناتج الآتي:<syntaxhighlight lang="text"> | ||
Number of arguments: 3 | Number of arguments: 3 | ||
Second argument is: 2 | Second argument is: 2 | ||
</syntaxhighlight>المثال 2: مثال عن استخدام الدالّة func_get_arg() قبل و بعد الاصدار PHP 5.3<syntaxhighlight lang="php"> | </syntaxhighlight>المثال 2: مثال عن استخدام الدالّة <code>func_get_arg()</code> قبل و بعد الاصدار PHP 5.3<syntaxhighlight lang="php"> | ||
test.php | test.php | ||
<?php | <?php | ||
سطر 69: | سطر 69: | ||
?> | ?> | ||
</syntaxhighlight>سينتج المثال السابق قبل الاصدار PHP 5.3 الناتج الآتي :<syntaxhighlight> | </syntaxhighlight>سينتج المثال السابق قبل الاصدار PHP 5.3 الناتج الآتي :<syntaxhighlight lang="text"> | ||
'Second arg' | 'Second arg' | ||
</syntaxhighlight>سينتج المثال السابق في الاصدار PHP 5.3 ومابعد الناتج الآتي :<syntaxhighlight> | </syntaxhighlight>سينتج المثال السابق في الاصدار PHP 5.3 ومابعد الناتج الآتي :<syntaxhighlight lang="text"> | ||
Warning: func_get_arg(): Called from the global scope - no function | Warning: func_get_arg(): Called from the global scope - no function | ||
context in /home/torben/Desktop/code/ml/fga.inc on line 3 | context in /home/torben/Desktop/code/ml/fga.inc on line 3 | ||
false | false | ||
</syntaxhighlight>المثال 3: مثال عن استخدام func_get_arg() بوسائط تُمرَّر بالقيمة وبالمرجعية<syntaxhighlight lang="php"> | </syntaxhighlight>المثال 3: مثال عن استخدام <code>func_get_arg()</code> بوسائط تُمرَّر بالقيمة وبالمرجعية<syntaxhighlight lang="php"> | ||
<?php | <?php | ||
function byVal($arg) { | function byVal($arg) { | ||
سطر 93: | سطر 93: | ||
byRef($arg); | byRef($arg); | ||
?> | ?> | ||
</syntaxhighlight>ناتج المثال السابق في الاصدار PHP 7 هو:<syntaxhighlight> | </syntaxhighlight>ناتج المثال السابق في الاصدار PHP 7 هو:<syntaxhighlight lang="text"> | ||
As passed : 'bar' | As passed : 'bar' | ||
After change : 'baz' | After change : 'baz' | ||
As passed : 'bar' | As passed : 'bar' | ||
After change : 'baz' | After change : 'baz' | ||
</syntaxhighlight>ناتج المثال السابق في الاصدار PHP 5 هو:<syntaxhighlight> | </syntaxhighlight>ناتج المثال السابق في الاصدار PHP 5 هو:<syntaxhighlight lang="text"> | ||
As passed : 'bar' | As passed : 'bar' | ||
After change : 'bar' | After change : 'bar' | ||
سطر 112: | سطر 112: | ||
هذه الدّالة تعيد نسخة من الوسائط الممرّرة فقط، ولا تهتم بالوسائط الافتراضية (غير الممرَّرة إلى الدالة مباشرةً). | هذه الدّالة تعيد نسخة من الوسائط الممرّرة فقط، ولا تهتم بالوسائط الافتراضية (غير الممرَّرة إلى الدالة مباشرةً). | ||
انظر أيضًا | == انظر أيضًا == | ||
---- | ---- | ||
* | * الدالّة <code>[[PHP/func num args|()func_num_args]]</code>: إعادة عدد الوسائط الممرّرة إلى الدّالة. | ||
* الدالّة<code>[[PHP/func get args|func_get_args()]]</code> : إعادة مصفوفة فيها الوسائط المُمرَّرة إلى الدالة. | |||
* | |||
== مصادر == | == مصادر == | ||
---- | ---- | ||
* [http://php.net/manual/en/function.func-get-arg.php صفحة الدالة func_get_arg في توثيق PHP الرسمي.] | * [http://php.net/manual/en/function.func-get-arg.php صفحة الدالة func_get_arg في توثيق PHP الرسمي.] |
مراجعة 12:42، 15 أبريل 2018
(PHP 4, PHP 5, PHP 7)
تُعيد الدالّة func_get_arg()
وسيطًا من قائمة الوسطاء.
الوصف
mixed func_get_arg ( int $arg_num )
تحصل الدالّة func_get_arg()
على وسيط من قائمة وسطاء الدّالة المعرّفة من قبل المستخدم.
من الممكن أن تُستخدم هذه الدّالة بالتزامن مع الدالّة func_get_args()
والدالّة func_num_args()
للسماح للدالات المعرّفة من قبل المستخدم بقبول قوائم وسطاء متغيرة الطول.
المعاملات
arg_num
فهرس الوسيط المُراد الحصول على قيمته. لاحظ أنَّه تُعَدّ وسائط الدّالة بدءًا من الصفر.
القيم المعادة
تُعيد الدالّة func_get_arg()
الوسيط المحدّد، أو تُعيد FALSE
في حال حدوث الخطأ.
سجل التغييرات
الإصدار | الوصف |
---|---|
5.3.0 | يمكن الآن استخدام هذه الدالة في قائمة المعاملات. |
5.3.0 | إذا استُدعيت هذه الدالّة من النطاق الخارجي لملف مُضمَّن من خلال استدعاء include أو require من داخل دالّة في الملف المستدعي، فستولد تحذيرًا وتُعيد FALSE .
|
الأخطاء والاستثناءات
تولّد الدّالة func_get_arg()
تحذيرًا إذا استدعيت من خارج دالة معرّفة من قبل المستخدم، أو إذا كانت قيمة arg_num
أكبر من عدد الوسطاء الممرّرة.
أمثلة
المثال 1: مثال عن استخدام الدالّة func_get_arg()
<?php
function foo()
{
$numargs = func_num_args();
echo "Number of arguments: $numargs\n";
if ($numargs >= 2) {
echo "Second argument is: " . func_get_arg(1) . "\n";
}
}
foo(1, 2, 3);
?>
سينتج المثال السابق الناتج الآتي:
Number of arguments: 3
Second argument is: 2
المثال 2: مثال عن استخدام الدالّة func_get_arg()
قبل و بعد الاصدار PHP 5.3
test.php
<?php
function foo() {
include './fga.inc';
}
foo('First arg', 'Second arg');
?>
fga.inc
<?php
$arg = func_get_arg(1);
var_export($arg);
?>
سينتج المثال السابق قبل الاصدار PHP 5.3 الناتج الآتي :
'Second arg'
سينتج المثال السابق في الاصدار PHP 5.3 ومابعد الناتج الآتي :
Warning: func_get_arg(): Called from the global scope - no function
context in /home/torben/Desktop/code/ml/fga.inc on line 3
false
المثال 3: مثال عن استخدام func_get_arg()
بوسائط تُمرَّر بالقيمة وبالمرجعية
<?php
function byVal($arg) {
echo 'As passed : ', var_export(func_get_arg(0)), PHP_EOL;
$arg = 'baz';
echo 'After change : ', var_export(func_get_arg(0)), PHP_EOL;
}
function byRef(&$arg) {
echo 'As passed : ', var_export(func_get_arg(0)), PHP_EOL;
$arg = 'baz';
echo 'After change : ', var_export(func_get_arg(0)), PHP_EOL;
}
$arg = 'bar';
byVal($arg);
byRef($arg);
?>
ناتج المثال السابق في الاصدار PHP 7 هو:
As passed : 'bar'
After change : 'baz'
As passed : 'bar'
After change : 'baz'
ناتج المثال السابق في الاصدار PHP 5 هو:
As passed : 'bar'
After change : 'bar'
As passed : 'bar'
After change : 'baz'
ملاحظات
باعتبار أن هذه الداّلة تعتمد على النطاق الحالي (current scope) لتحديد تفاصيل المعامل، فلا يمكن استخدامها كمعاملات دالة في الاصدارات السابقة للإصدار 5.3.0. إذا كان يتوجب تمرير هذه القيمة، فيجب أن تُسند النتائج إلى متغير، ثم تمرير ذلك المتغير.
إذا مُرّرت الوسائط بواسطة المرجعية، فإنّ أي تغيير في الوسائط سينعكس على القيم المُعادة باستخدام هذه الدّالة. بدءًا من الاصدار PHP 7 ستعاد القيم الحاليّة أيضًا إذا مُرّر الوسائط بواسطة القيمة.
هذه الدّالة تعيد نسخة من الوسائط الممرّرة فقط، ولا تهتم بالوسائط الافتراضية (غير الممرَّرة إلى الدالة مباشرةً).
انظر أيضًا
- الدالّة
()func_num_args
: إعادة عدد الوسائط الممرّرة إلى الدّالة. - الدالّة
func_get_args()
: إعادة مصفوفة فيها الوسائط المُمرَّرة إلى الدالة.