-
المساهمات
5232 -
تاريخ الانضمام
-
تاريخ آخر زيارة
-
عدد الأيام التي تصدر بها
52
نوع المحتوى
ريادة الأعمال
البرمجة
التصميم
DevOps
التسويق والمبيعات
العمل الحر
البرامج والتطبيقات
آخر التحديثات
قصص نجاح
أسئلة وأجوبة
كتب
دورات
كل منشورات العضو Adnane Kadri
-
الشعبية وراء JSON هي في كونها: خفيفة الحجم. أكثر قابلية للقراءة مقارنة بصيغ أخرى من مثل XML. هذا بجانب أنها تتكامل مع أغلب لغات البرمجة، إذ تحتوي كل لغة رئيسية واحدة تقريبًا على شكل من أشكال المكتبات أو الوظائف المضمنة لتحليل سلاسل JSON إلى كائنات أو فئات بهذه اللغة من مثل json_encode و json_decode في PHP و توابع الكائن JSON في جافاسكربت وغيرها. العمل بها سهل وعام. فكل ما تحتاجه هو تصدير البيانات بهاته الصيغة وسيجعل تطبيقك قابلا للربط والتواصل مع اي تطبيق آخر من أي لغة او بيئة عمل. عدم محدوديتها، يوجد بعض الرموز والمحارف التي لا يمكن العمل بها في صيغ أخرى على عكسها. كل هاته الشعبية جعلتها تحتل مكانة مميزة في الويب، بجانب اقتحامها مجالات البيانات الوصفية والمخططات Metadata & schema وغيرها.
- 2 اجابة
-
- 1
-
-
يمكنك الاستعانة بأية مواقع للاستلهام أو التغذية البصرية، كأن تقوم بالعمل على تصميم الموقع ككل او أحد او بعض مكوناته فقط. فيما يلي بعض المواقع التي تقدم سلسلة من التصاميم وواجهات المستخدم وعناصرها: موقع codepen: وهو بيئة تطوير اجتماعي لمصممي ومطوري الواجهة الأمامية. موقع webdesign-inspiration: وهو الآخر موقع لإستلهام أفكار تصميم الويب. يمكنك ايضا استعمال pinterest أو dribbble للبحث عن افكار او تصاميم في أي مجال. موقع siteinspire هو أيضا مكان لا بأس به لنفس الغرض.
- 5 اجابة
-
- 1
-
-
ارى ان الحاوي section يمتلك عرضا ثابتا (400px)، يمكنك ضبطه في حالة الشاشات الأصغر، فعلى سبيل المثال: نعطي عرضا نسبيا للعنصر مقدر بكامل عرض الحاوي، سنتأكد بهذا أن عرض الحاوي لن يتجاوز عرض شاشة العرض: @media only screen and (max-width: 600px){ section{ width: 100%; } } الصورة التي تقوم بعرضها ايضا تمتلك نفس المشكلة، تأكد من تقليل أبعاد الى أخرى اكثر مناسبة: @media only screen and (max-width: 600px){ img{ width: 250px; height: 250px; } } يمكنك اختصار الكتابتين الى: @media only screen and (max-width: 600px){ section{ width: 100%; } img{ width: 250px; height: 250px; } }
- 1 جواب
-
- 1
-
-
هلا قمت بتحديد قيمتي المتغيرين NumberOfPages و adsTotalNumber من داخل شرط التحقق بدلا عن خارجه؟ يكون ذلك كـ: if ($category==0 && $subCategory==0 && $state==0 ) { $stmt=$conn->prepare(" SELECT * FROM items join categories on categories.cat_id=items.CAT_ID join sub on items.subcat_id=sub.subcat_id JOIN country ON items.country_id=country.country_id JOIN state ON items.state_id=state.state_id JOIN city ON items.city_id=city.city_id WHERE country.country_id=? AND items.NAME LIKE '%$inputSearch%' order by feature desc limit $startFrom,$adsPerPage"); $stmt->execute(array($country)); $item= $stmt->fetchAll(); $adsTotalNumber=count($item); $NumberOfPages=ceil($adsTotalNumber/$adsPerPage); } ثم هل يمكنك تحديد بالضبط ما القيمتان المتعارضتان؟
-
لا تظهر أي مشكلة بالشيفرة او بالاستعلام، فهذا هو المفترض ان يحدث في تصفيح العناصر من قواعد البيانات، فعدم استعمالك للاستعلام LIMIT لن يقوم بتحديد اي فهرس ابتدائي او عدد صفوف معين يتم اقتطاعه. وفي حالة اقتطاعه عن طريق تحديد الاستعلام بـ: LIMIT $startFrom, 4 سيتم جلب الأربع عناصر الموالية للفهرس المحددة. أليس هذا هو المراد من تصفيح المنتجات؟ ما المشكلة التي تواجهها تحديدا؟
-
ايجاد افكار للمشاريع هو الأمر الآخر الذي ستتعلمه أكثر مع كبر دائرة خبراتك. ولكن لا يمنع هذا من وجود بعض الأفكار التي يمكن تطبيق عليها اغلب الافكار. من مثل: لغرض تحسين التعامل مع كائن الوقت في جافاسكربت نقوم ببناء عداد زمني أو ساعة حائطية نوظف فيها بجانب التوقيت تحويلات CSS مثلا. لغرض تحسين التعامل مع شجرة الوثيقة نقوم انشاء تطبيق to do list وبما انك في بداية الدورة، فسيكون الآن كافيا متابعة ما يقدم في الدورة والتطبيق العملي مع المدرب.
- 4 اجابة
-
- 1
-
-
الاحتراف في مجال ما لا يكون وليد لحظة معينة او قابلا للتأطير في مرحلة معينة فهو نتاج مرات عديدة من البناء والتطبيق العملي والممارسة والخبرة، فنفس التطبيق الذي تقوم ببناءه بعد الانتهاء تماما من الدورة وبعد زمن معين من الممارسة والتطبيق العملي سيكونان في مستويان مختلفان من الاحترافية. بدل التركيز على مثل هاته الأشياء يقترح الانطلاق في عمل مشاريعك وتوظيف افكارك الخاصة. سيساعدك هذا في قولبة أسلوب خاص بك يمكن ان يطلق عليه عملا محترفا. وبشكل عام، تعالج الدورة كامل النقاط التي ستساعدك في بلوغ هذا الهدف.
- 4 اجابة
-
- 1
-
-
بالمنطق الأبسط، لا تقوم مواقع التهنئات الا بوضع نص مخصص فوق صور او قوالب يختارها العميل، ويكون هدا عن طريق التعامل مع نموذج كائن شجرة الوثيقة DOM بشكل عادي. وصحيح هو أنك لا تجد من لا يقوم بهذا بشكله الأبسط ولذلك فإن هاته التطبيقات عادة ما تكون مبنية على أحد أطر عمل الواجهة الأمامية مثل VueJS أو ReactJS لتسهيل التعامل معها وانشاء نماذج أكثر فعالية وتفاعلية. ولتطبيق هاته الفكرة على نحو دقيق، ستحتاج تفكيك هذا السؤال الى عدة أسئلة أدق من مثل: كيف يمكن تحديد النص الذي يدخله المستخدم. كيف يمكن وضع هذا النص داخل حاوية ما. كيف يمكن تخصيص هذا النص. كيف يمكن تصدير هاته الصورة وطباعتها. بالنسبة للتعامل مع واتساب عن طريق الواجهة البرمجية، فلا أظن ان هنالك واجهة مجانية للأفراد فواتساب تقدم خدمة التعامل مع واجهتها كخدمة مدفوعة موجهة حصرا للأنشطة التجارية. يمكنك تسجيل نشاطك التجاري عن طريق الرابط التالي
- 5 اجابة
-
- 1
-
-
هل تتساءل عن كيفية انشاء موقع للتهنئات ام عن كيفية التعامل مع الواجهة البرمجية لاتس اب؟
- 5 اجابة
-
- 1
-
-
يتم ذلك بوساطة بوابات الدفع التي توفر واجهات برمجية أو مكتبات للتعامل مع كامل مراحل عمليات الدفع وتتبعها. وتختلف طريقة استعمال كل واحدة من هاته البوابات عن الأخرى، والتي تعمل وفق المنطق التالي: يقدم العميل او رزائر موقعك طلبا للدفع بتقديم معلومات الدفع الخاصة به. تأخذ بوابة الدفع هاته المعلومات وتشفرها وترسلها عبر قناة آمنة الى معالج الدفع. يأخذ معالج الدفع العميل عبر خطوات إنهاء الدفع. يتحقق معالج الدفع من نجاح الدفع ويعيد العميل الى الموقع الخاص بك. عموما، يتم اختيار بوابة دفع بحسب: الأمان والشهادات الالكترونية وموثوقية البوابة. رسوم الخدمات التي تقدمها البوابة. القبول الدولي (أي ان دولة العميل او عملائك المستهدفين يجب ان تكون ضمن الدول المدعومة من هاته البوابة). دعم العملاء. وفيما يلي بعض من اشهر بوابات الدفع: بوابة stripe بوابة بيبال بوابة 2checkout
- 1 جواب
-
- 1
-
-
قد تكون هاته من بين المشاكل المتكررة في ويب باك، يكون هذا عادة بتعارض يحدث ما بين الحزمتين html-loader و file-loader. نتأكد في حل المشكلة من استعمال نسخة أقدم من حزمة html-loader، يكون ذلك عن طريق تشغيل الأمر: npm i html-loader@1.3.2 أو باستبدال السطر الخاص بالحزمة في ملف package.json بـ: "html-loader":"^1.3.2" ثم اعادة تثبيت اعتماديات Node عن طريق تشغيل الأمر: npm run i ثم سيمكنك اعادة تشغيل خادم ويب باك او اخراج مجلد dist بشكل عادي. في حالة استمرار المشكلة يرجى ارفاق ملف package.json وملف اعداد webpack.config.js للنظر في المشكلة على نحو أدق.
- 5 اجابة
-
- 1
-
-
بجانب ما اقترحه المدرب وائل، يمكنك انشاء عنصرا مخصصا يحمل سمة توضيحية تخص عنصرا ما، فيما يلي الهيكلة العامة للعنصرين: <div class="tooltip"> العنصر الرئيسي <span class="title">عنصر السمة التوضيحية</span> </div> تنسيق العنصرين: /* العنصر */ .tooltip { position: relative; } /* عنصر السمة التوضيحية */ .tooltip .title { /* اخفاء العنصر بشكل افتراضي */ display:none; /* يجب تمليك العنصر الوضعية المطلقة */ position: absolute; } /* اظهار العنصر عند تمرير مؤشر الفأرة */ .tooltip:hover .title { display:initial; } لاحظ أن عنصر السمة هنا يقبل اي عناصر HTML وسيمكن عليه تطبيق أي تنسيقات CSS.
- 2 اجابة
-
- 1
-
-
حسب مدونة خمسات، فإنه توجد مجموعة من المعايير التي تتحكم في تصدر خدماتك أو خدمتك نتائج البحث، نذكر من بينها: التقييمات على الموقع معدّل سرعة استجابة البائع في الموقع تواجد البائع أثناء البحث في الموقع معدّل تسليم الطلبات استخدام الخدمات المطورة أغلب هاته الأمور، قد لا تكون متوفرة أو صعبة التحقيق بالنسبة للباعة الجدد، ولذلك فإنه سيكون عليك بذل بعض الجهد الاضافي للحصول على أول العملاء. ينصح مثلا بالمشاركة في طلبات الخدمات الغير موجودة أو متابعتها بشكل دائم ومحاولة إنشاء خدمة مميزة وفريدة ومطلوبة في نفس الوقت.
-
أظنك تحتاج تفيكيك السؤال "هل أنا جاهز للعمل الحر" إلى أسئلة أدق من مثل "هل بإستطاعتي العمل على المشاريع المعروضة" و "هل المهارات المطلوبة أمتلكها بالفعل". فأنت ستحتاج مجالا تقوم بالبحث فيه والاطلاع على طبيعة المشاريع ووصفها وأمثلة عنها والمهارات المطلوبة فيها. وعليه سيمكنك تقدير نفسك ضمن هاته المشاريع. وبشكل عام، نعم سيمكنك الانطلاق في مشاريع العمل الحر الخاصة بتطوير واجهات المستخدم بعد إنهاء هاته الدورة. بالنسبة لسؤالك الثاني حول خدمات خمسات، فبشكل عام ستحتاج: أن يكون العنوان واضحاً باللغة العربية، يجب أن يصف الخدمة التي تريد أن تقدمها. تشترط خمسات أن لا تدخل رموزاً أو كلمات مثل "حصرياً"، "لأول مرة"، "لفترة محدود".. الخ. أن يكون وصف الخدمة بدقة يتضمن جميع المعلومات والشروط. وتمنع خمسات وضع البريد الالكتروني، رقم الهاتف أو أي معلومات اتصال أخرى. أن يمتلك كلمات مفتاحية متعلقة بالخدمة مثال: تطوير مواقع, ووردبريس, تصميم هذا وتعتبر كل خدمة حالة خاصة لها وصفها الخاص وعنوانها الخاص الذي يميزها دون باقي الخدمات. يمكنك الاستزادة بالاطلاع على هاته المقالة 10 نصائح لزيادة فرص بيع خدماتك على خمسات
- 1 جواب
-
- 1
-
-
يمكنك استخدام الوظيفة var_export لتصدير تمثيل المتغير الممرر عبرها كسلسلة نصية: <?php $done = true; echo var_export($done ); // true $done = false; echo var_export($done ); // false الدالة var_export() في PHP حسب ويكي حسوب.
- 2 اجابة
-
- 1
-
-
هذا ليس خطأ، فهو إشعار. ويتم اخراج هذا الإشعار لأن الوظيفة end () تتوقع مرجعًا reference لشيء تريد تغييره والذي يتوقع ان يكون متغيرا، في حين انك تقوم بإسناد التعريف مباشرة. أي انه لن يمكنك تمرير نتيجة explode مباشرة اليها دون حفظها في متغير اولا واستدعاءها بمرجعية هذا المتغير. ففي المثال الذي لديك هي متواجدة في الذاكرة ولا يشير اليها أي متغير وبطبيعة الحال فإنه لن يمكنك انشاء اشارة اليها. ولذلك فإن الحل الأول هو انشاء مرجع، او بمعنى آخر تخزين الخرج في متغير وتمريره كمعامل للوظيفة end. كحل آخر، يمكنك تجاهل هذا الإشعار والتغاضي عما يخرجه مباشرة ويكون ذلك عن طريق استخدام عامل التجاهل: $file_name = @end(explode('/', $file_path));
- 2 اجابة
-
- 1
-
-
تعتبر الوظيفة empty طريقة للتحقق من ما ان كان متغير ما يحمل قيمة فارغة، القيم الفارغة المعتبرة هي: "" سلسلة نصية فارغة. 0 كعدد. 0.0 كعدد عشري. "0" كسلسلة نصية. Null كقيمة فاضية false كقيمة بوليانية [] كمصفوفة فارغة يقتضي هذا ان يكون المتغير معرفا بالفعل، ولكنه يحمل احد القيم المعتبرة فارغة. في حين ان الذي تقوم به الوظيفة isset هو التحقق من ما ان كان هذا المتغير معرفا أول الأمر أم لا، لاحظ المثالين: <?php $emptyVar = ''; $emptyVar2 = []; $notEmpty = 'Hsoub'; echo empty($emptyVar); // true echo empty($emptyVar2); // true echo empty($notEmpty); // false echo isset($unsetVar); // false وبالتالي، المثال الذي لديك يتحقق من ما ان كان المتغير معرفا، ولا يحمل قيمة فارغة. كطريقة اقصر يمكنك مباشرة استعمال الوظيفة empty وحدها، وذلك لأن هاته الأخيرة تقوم بإعادة قيمة بوليانية false في حالة عدم تعريف المتغير، فبدل: if ( isset($myArr[1]) AND !empty($myArr[1]) ) { // do something } يمكنك مباشرة استعمال: if ( !empty($myArr[1]) ) { // do something } الدالة empty() في PHP الدالة isset() في PHP
- 2 اجابة
-
- 1
-
-
بالمفهوم البسيط، يستعمل الموجه @section لتعريف قسم أو جزء لإضافة المحتوى، بينما تعرض التعليمة @yield وتعرف محتوى قسم معيّن. على سبيل المثال: نقوم بتحديد عنوان الصفحة في العنصر الابن عن طريق حقنه الى المعامل الثاني لـلموجه section @section('title', 'Page Title') نقوم بتحديد المكان الذي سيتم فيه حقن أي محتوى يسند الى التعليمة section : <head> <title>App Name - @yield('title')</title> </head> أي: تستعمل yield لتحديد موضع حقن العناصر والمحتويات في ملف العرض الأب. تستعمل section لتعريف قسم معين في ملف العرض الابن.
- 1 جواب
-
- 1
-
-
يمكنك استخدام التعابير النمطية للتحقق من ان عبارة او سلسلة نصية ما هي ما يماثل الشكل العام لعناوين البريد الالكتروني، فيما يلي مثال عن التعبير النمطي الذي نريده: $pattern = "/^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,})$/i"; مثال عملي : function isValidEmail($str) { $pattern = "/^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,})$/i"; return preg_match($pattern ,$str); } echo isValidEmail('jhondoe@email.com'); // true echo isValidEmail('jhondoeemail.com'); // false يمكنك الاستزادة بالاطلاع على كيفية صياغة التعبيرات النمطية في PHP
-
أحب تعريف بيانات المشرف وادراجها بقواعد البيانات في ملف تهجير جدول المشرفين بشكل مرافق، يكون هذا عمليا في الحالات التي نقوم بها بتنفيذ أمر التهجير php artisan migrate في الانتاج، وكذلك بعد تصدير قواعد البيانات على الخادم المحلي وتضمينها في قواعد البيانات خادم الاستضافة لديك. يمكنك تعريف التابع التالي بملف التهجير المرافق: /** * Run the migrations. * * @return void */ public function up() { Schema::create('admins', function (Blueprint $table) { $table->id(); $table->string('name'); $table->string('email')->unique(); $table->timestamp('email_verified_at')->nullable(); $table->string('password'); $table->rememberToken(); $table->timestamps(); }); $this->createDefaultAdmin(); } /** * Creates the deafult admin for app * * @return void */ private function createDefaultAdmin() { App\Models\Admin::create([ 'name' => 'admin admin', 'email' => 'admin@admin.co', 'password' => Illuminate\Support\Facades\Hash::make('@password'), ]); } وسيتم انشاءه كل مرة تقوم فيها بتهجير قواعد البيانات.
- 2 اجابة
-
- 2
-
-
لا أظن هنالك مشكلة بقواعد البيانات لديك، فخرج الخطأ تقومين بطباعته بشكل مخصص وذلك في الشطر الأول من الشرط if المقيد بالشرط : $file = file_put_contents($this->getNameWithPath() ,file_get_contents('php://input')); قد تُرجع هذه الوظيفة file_get_contents قيمة بوليانية false، ولكنها قد تُرجع أيضًا قيمة غير منطقية يتم تقييمها على خطأ. تستعمل هاته الوظيفة في مضمونها الدوال fopen و fclose وfwrite ولذلك فإن أي مشكل بهاته الوظيفة سيؤدي بالضرورة الى خطأ بعملها. تأكدي أولا من انك تمتلكين كامل صلاحيات الكتابة والفتح والاغلاق للمجلد المستهدف المراد حفظ الملف فيه، ثم سيمكنك اعادة تنفيذ السكربت. ان استمرت المشكلة، يرجى ارفاق الشيفرات بشكل مكتوب بدل التقاط صور لها، وذلك حتى يمكن اختبار الشيفرات عمليا. فيما يلي توثيق الدالة file_put_contents.
-
أظنك قد تحتاج وصول SSH لتنفيذ مثل هكذا أمر. قد يمكنك تنفيذ أمر تشغيل السكربت المستهدف عن طريق الأمر: php scriptname.php يمكنك استعمال الوظيفة exec لهذا الأمر. كالتالي: exec('php scriptname.php') ان كنت قد تحتاج ايضا التعامل مع خرج هذا السكربت على نحو معين، يمكنك الاستفادة من هاته الاجابة لسؤال سابق لك:
- 2 اجابة
-
- 1
-
-
رغم أن الأمر يتشابه كثيرا الى ان التفاصيل تعتمد بالدرجة الأولى على الاستضافة التي ستقوم برفعها عليها. فعلى الاستضافات المشتركة مثلا لن تحتاج -في الغالب- تثبيت الحزم اللازمة على الاستضافة، وانما ستحتاج: تكوين مجلد vendor محليا ضمن ملفات مشروعك عن طريق الأمر composer install، ولا حاجة من هذا ان كنت تمتلك هذا المجلد بالفعل. ثم رفع ملف مشروعك مضغوطا الى المسار العام للاستضافة المشتركة التي لديك (يكون هذا عادة باسم public_html). فك الضغط واخراج الملفات داخل هذا المسار. اخراج ملف index.php من مجلد public الى داخل هذا المسار (أي الى داخل public_html). بعد اخراج ملف index.php ستحتاج القيام ببعض التعديلات الموافقة لهذا النقل، ويكون ذلك بتعديل السطرين: require __DIR__.'/../vendor/autoload.php'; $app = require_once __DIR__.'/../bootstrap/app.php'; الى: require __DIR__.'/vendor/autoload.php'; $app = require_once __DIR__.'/bootstrap/app.php'; ستحتاج ايضا بشكل منفصل انشاء قواعد البيانات عن طريق تصديرها من مدير قواعد البيانات لديك على الخادم المحلي، وبالطبع انشاء مستخدم بكلمة سر. وأخيرا ربط هاته البيانات بالتطبيق عن طريق التعديل على ملف البيئة env. كشيء جانبي آخر، قد تضطر الى تكوين الروابط الرمزية symlinks ان كنت تستعملها على الخادم المحلي. يمكنك لذلك عن طريق انشاء مسار مخصص لتنفيذ هذا الأمر كـ : Route::get('storage/symbolic_link', function(){ Artisan::call('storage:link'); }) ثم زيارة المسار المستهدف لتنفيذ هذا الأمر. (لا تنسى تضمين الواجهة Artisan).
- 2 اجابة
-
- 1
-
-
ينبغي أولا فهم ما الذي تقوم به الدوال المولدة generators قبل التطرق لـ yield نفسها، فالأولى تقتضي استعمال الأخيرة. تعد المولدات في PHP تقدم طريقة أسرع وأسهل لإستخدام المكررات Iterators، فبدل السياق التالي لإضافة 100 الى كل عنصر من مصفوفة عددية: function myFunct($items) { $result = []; foreach ($items as $item) { $result[] = $item + 100; } return $result; } يتم كتابة صيغة المولد كـ: function myFunct($items) { foreach ($items as $item) { yield $item + 100; } } ففي الأولى: يتم انشاء مصفوفة جديدة. نقوم تباعا باستعمال تكرارة foreach بالإضافة الى المصفوفة الجديدة كل عنصر من عناصر المصفوفة القديمة مضافا اليه 100. وفي الأخير نقوم بإعادة المصفوفة الجديدة كخرج. أما في الثانية: فنحن نقوم مباشرة بإضافة الـ 100 الى كل عنصر من عناصر المصفوفة القديمة. وكل هذا يكون دون الحاجة حتى الى اعادة خرج أو اعادة تعيين مصفوفة جديدة لإعادتها كخرج لاحقا. و yield هنا هي أساس عمل هاته الدالة المولدة، فهي تعمل بشكل مشابه لـ return سوى أن هاته الأخيرة توقف تنفيذ الشيفرة. و yield تواصل تنفيذها الى القيمة التي ما بعدها. بمعنى: لو استقبلت الدالة المولدة المصفوفة [1,2] فهي لن تعيد 1 وتوقف تنفيذ الشيفرة عند اول تكرارة، بل ستقوم بإعادة تعيين 1 بالقيمة المسندة الى yield وتواصل العملية الى 2 وهكذا. بجانب فرق السرعة والضغط على الخادم الذي يكون في صالح المولدات لما يكون الأمر متعلق بالمكررات، يختلف العائد في كل من الأولى والثانية قليلا. فعند استدعاء الدالة المولِّدة للمرة الأولى تعيد الدالة كائنًا من الصنف Generator.ولو قمت بتفحص عائد الدالة المولدة سترى ذلك: function myFunct($items) { foreach ($items as $item) { yield $item + 100; } } print_r(myFunct([0 ,1 , 2])); الخرج: Generator Object ( ) في حين ان خرج الدالة العادية الأولى سيكون عاديا: [100 ,101 , 102] هذا الكائن المعاد يطبق واجهة المكرر Iterator يمكن الوصول الى قيمها التي تعرف كخصائص كالتالي: function myFunc($items) { foreach ($items as $item) { yield $item + 100; } } foreach(myFunc([1,2,3]) as $i){ echo $i.'/'; } // => 101/102/103/ قد تحتاج الاستزادة بالتعرف على المولدات في PHP و PHP Object Iteration.
- 1 جواب
-
- 1
-