-
المساهمات
5196 -
تاريخ الانضمام
-
تاريخ آخر زيارة
-
عدد الأيام التي تصدر بها
52
نوع المحتوى
ريادة الأعمال
البرمجة
التصميم
DevOps
التسويق والمبيعات
العمل الحر
البرامج والتطبيقات
آخر التحديثات
قصص نجاح
أسئلة وأجوبة
كتب
دورات
كل منشورات العضو Adnane Kadri
-
إن كانت الشيفرة المرفقة: $(function () { var currentDate = new Date(); $('#currentYear').text(currentDate.getFullYear()); }) موضوعة بملف script.js فإنك ستحتاجين وضع سطر تضمين هذا الملف أسفل سطر تضمين جيكويري لأنه يقتضيها بالفعل: <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.7.0/jquery.min.js"></script> <script src="js/script.js"></script>
- 2 اجابة
-
- 1
-
لا أظن أن ذلك متاح، لا يمكن محو سؤال تم نشره في الأكاديمية. في حالة الحاجة، يمكنك بدل ذلك القيام بتعديله، ووضع بدل السؤال نقطة أو فاصلة وكتابة "حذف السؤال" مكان التبرير، سوف يمكن لأحد المشرفين آنذاك إخفاء سؤالك بشكل تام.
- 1 جواب
-
- 1
-
استعمل محررات الأكواد للإحتفاظ بشيفرة معينة في ملف معين، قم أولا بإنشاء ملف معين. أعطه اسما وليكن index.html ولنضعه على سطح المكتب. قم بفتح الملف باستخدام vs code مثلا. قم بكتابة الشيفرة التي تريد حفظها. احفظ الملف باختيار save من القائمة file أو باستخدام اختصار لوحة المفاتيح ctrl + s. أغلق المحرر. سوف يمكنك مستقبلا العودة لهذا الملف واستعراض محتواه أو تعديله بنفس الطريقة باستخدام vs code.
- 2 اجابة
-
- 1
-
غرض التركيز على شيء واحد في البداية هو غالبا لضمان عدم التشتت بجانب ضمان استفادة قصوى مما يحاول الطالب تعلمه، ولذلك فإن التعرض للعديد من المصادر المختلفة بشأن معلومة ما أو التعرض لمادة علمية تختلف كليا عما يحاول تعلمه قد يؤدي به إلى عدم إلتقاط أي منهما، فبدل أن يزود جهوده لإكتساب معارف أكثر، سوف يجد نفسه لم يكتسب ولا واحدة فيهما. ولذلك، في البداية قد لا يكون ذلك ضروريا وقد يغلب ضره على نفعه، ولكن لا مشكلة في ذلك مع التقدم في المسارات وتحسن مستواك. فمع تقدمك، سوف تزداد قدرتك الاستيعابية ومقدرتك على التنظيم والفهم. وعليه، فإن واحدة من أفضل المقاربات غالبا لذلك هي تعلم مادة علمية ثانية بالتوازي مع مادة علمية أخرى بشرط أن يكون المتعلم قد تقدم في إحداهما. أيضا انظر للدافع من وراء ذلك، ما الذي يستعجلك للقيام بذلك؟ هل هو الوقت، الفضول أو أي شيء بالضبط؟ فإن لم يكن سببا واقعيا أو دافعا ملحا ما عليك إلا تجاهله، وتذكر أن طريق التعلم لا تقطع إلا واحدة واحدة، ولا يمكن بأي حال من الأحوال اختصار الطريق أو القفز للمرحلة الأخيرة مرة واحدة.
-
جرب وضع الصورة كعنصر img يحتل عرضا كاملا من الشاشة خلف باقي العناصر بدل وصفها كخلفية لعنصر home. فيكون: <div class="home"> <img src="path/to/image" class="bg-img" /> ثم لنعطها التنسيقات التالية: .home{ position: relative; } .bg-img{ postion: absolute; top:0; right:0; width: 100%; } قد يحل هذا مشكلتك، وفي حالة عدم اشتغال القواعد بصورة صحيحة حاول التحكم في z-index الخاصة بالصورة لتظهر خلف العناصر. طبعا لا تنسى التخلص من الشيفرات الخاصة بالخلفية لكي يتم ذلك بصورة صحيحة.
-
أظن أن المشكلة التي تحدث هي على مستوى العميل وليس على مستوى الخادم، لأن ما يحدث على مستوى الخادم منطقي وشيء عادي، ومتى ما تلقى الخادم معرفا صحيحا فهو سيقوم بحذف المستخدم وفق الشروط المقدمة. كما أن الخطأ يظهر على مستوى المتصفح، مما يعني أن الخادم لا دخل فيه. الخطأ يشير تحديد إلى مشكلة بقراءة الخاصية id_ من currentUser، والتي يبدوا أن هنالك مشكلة بتصريحها بداخل مكون رياكت. ابحث عن الأسطر الخاصة بها وانظر ما ان كنت تقوم بتصريحها على وجه صحيح. أيضا تأكد من ما ان كانت القيمة مساوية لـ null : const handleDelete = async () => { console.log(currentUser) /*const deleteProfile = await axios.delete(`/users/${currentUser._id}`); dispatch(logout()); navigate("/signin");*/ } في حال ما كان ذلك، أعد النظر في طريقة تصريحك لـ currentUser
- 1 جواب
-
- 1
-
مثل هذا السؤال عام جدا، ولكن عموما، لتصميم تطبيق لنظام Android، يجب أن تتعلم البرمجة باستخدام لغة Java أو Kotlin، والاستفادة من Android Studio كبيئة تطوير متكاملة (IDE) لبناء التطبيقات. فيما يلي بعض الخطوات الأساسية الشائعة عادة للبدء في تصميم تطبيق Android: تعلم لغة البرمجة: تعلم أساسيات إحدى لغات البرمجة المدعومة في تطوير تطبيقات Android، وهي Java و Kotlin. تستطيع الاختيار بينهما بناءً على تفضيلاتك والمصادر المتاحة للتعلم. تثبيت Android Studio: حمل وقم بتثبيت بيئة تطوير Android Studio من الموقع الرسمي للأداة. ستجد العديد من الدروس عبر الإنترنت لمساعدتك في تثبيتها وإعدادها. دراسة أساسيات تطوير التطبيقات: تعلم أساسيات تطوير التطبيقات من خلال القراءة والمتابعة لدروس ومصادر تعليمية متاحة عبر الإنترنت. يمكنك البدء بتصميم وتطوير تطبيقات بسيطة وزيادة تعقيد المشاريع تدريجياً. تصميم واجهة المستخدم (UI): استخدم محرر واجهة المستخدم في Android Studio لتصميم واجهة المستخدم الخاصة بتطبيقك. يمكنك استخدام تخطيطات مسبقة، أو تصميم واجهة مخصصة. قد يكون من العملي أكثر أخذ نظر أعم عن مجال البرمجة ككل قبل الإنطلاق في تطوير تطبيقات الأندرويد، المقالة التالية تأخذك من الصفر عبر كل ذلك:
- 3 اجابة
-
- 1
-
بشكل عام؟ لا أظن ذلك، ولكنه سيقوم باستهلاك بعض موارد الحاسوب أثناء عملية التطوير، البناء والتشغيل. فبرنامج Expo يستخدم موارد الحاسوب مثل الذاكرة العشوائية (RAM) ووحدة المعالجة المركزية (CPU) لتشغيل الخدمات والمحاكاة المحلية أثناء تطوير التطبيق. قد يكون هناك تأثير على أداء الحاسوب إذا كانت الموارد محدودة. أيضا إذا قررت استخدام المحاكي لاختبار التطبيق على جهاز محاكي مثل Android Emulator أو iOS Simulator، فسيتطلب ذلك المزيد من الموارد مقارنةً بتشغيل تطبيقات عادية بطبيعة الحال. نفس الشيء بالنسبة لاستخدام موارد الشبكة، خلال تطوير التطبيق باستخدام Expo، قد تقوم بتحميل البيانات من الإنترنت أو التفاعل مع خوادم أخرى، وهذا قد يستهلك موارد الشبكة ويؤثر على استقرار الاتصال.
- 3 اجابة
-
- 1
-
عادة ما يتم خزنها في ملف env. على الخادم يكون الوصول إليها متاحا من قبل التطبيق فقط، وبوساطة حزم ومكاتب مثل dotenv سوف يكون من السهل إدارة هاته المفاتيح أو الوصول إليها من خلال تطبيقك. قد تتوفر بعض الاستضافات من مثل Heroku أو AWS على خدمات إدارة المفاتيح ضمن ميزات خطط استضافتها، وهي توفر تشفيرا وأمانا أعلى من السابق. بحيث يتم تصريحها ضمن استمارات ونماذج في الاستضافة ضمن نطاق التطبيق، وسيمكن الوصول إليها من قبل التطبيق بشكل عادي. أما بخصوص سؤالك عن طريقة قراءة المتغيرات، فلا حاجة لتغييرها أثناء عملية البناء والنشر (مثل توليد الإصدار النهائي من التطبيق)، يمكنك الاستمرار في اعتماد الطريقة مادام ملف متغيرات البيئة مؤمنا.
- 4 اجابة
-
- 1
-
هل تقومين بتصفح مشروعك بإستخدام pretty url أم بإستخدام رابط عادي ؟ http://localhost:8000/ عموما، جربي التعديل على قيمة APP_URL من ملف env. APP_URL=http://localhost:8000/ أو: APP_URL=http://bookstore.test/ في حالة ما كنت تقومين بإستخدام pretty url هل حل ذلك المشكلة لديك؟
- 5 اجابة
-
- 1
-
لم أواجه أي مشكلة والتنسيقات تظهر لدي بشكل عادي. هل هنالك صفحة معينة تظهر فيها المشكلة؟ قد يكون ذلك بسبب الكاش، تأكدي من محو كاش ملفات العرض خصوصا: php artisan view:clear أيضا تأكدي ما ان كانت توجد هنالك مشاكل تظهر في console بخصوص تطبيق التنسيقات.
- 5 اجابة
-
- 1
-
وعليكم السلام، عند اختيار استضافة لمشروعك على Django، هناك عدة عوامل يجب أن تنظر فيها لتحديد الخيار الأنسب لك. من بين الخيارات التي ذكرتها (Digital Ocean و Hostinger). وهما حقيقة واحدتان من أحسن الاستضافات على الساحة حاليا. فيما يلي مقارنة بسيطة ما بينهما: من حيث الأداء والسرعة: Digital Ocean معروفة بأدائها الجيد وإمكانية تخصيص الموارد وفقًا لاحتياجاتك. Hostinger أيضًا تقدم خيارات متعددة للخوادم وتوفير السرعة بحسب خطة الاشتراك. من الأمان: كلاهما على قدر عال من الأمان. من حيث السعر: يجب أن تتوافق ميزانيتك مع تكاليف الاستضافة. Hostinger عادة تقدم خيارات اقتصادية مقارنةً بـ Digital Ocean. من حيث سهولة الاستخدام: رغم أنها أقرب للتجربة الشخصية إلا أني أعد هوستنجر أسهل من حيث إدارة الموارد والملفات. من حيث الدعم الفني: هوستنجر لها دعم نشط، وعادة ما يتم الرد في خلال دقائق فقط. نفس الشيء بالنسبة لدجتل اوشن. في الأخير، كنت لأختار Digital ocean لتطبيق Django كونها استضافة يمكن تخصيص الموارد فيها بحسب الاحتياجات. هذا ويمكن إعداد استضافة مخصصة كاملة لها، الأمر الذي يجعل من الأفضل الأخذ بها.
- 3 اجابة
-
- 1
-
مرحبا رباب، ان كان السؤال يخص درسا من دروس الدورات، فينصح بوضع تعليق في قسم تعليقات الطلبة للمتابعة معك خلال الدرس. بخصوص مشكلتك، يرجح أن تكون هنالك مشكلة أساسا بحقن سطر تضمين ملفات css في ملف النسق layout الذي يستعمله ملف العرض الذي يعرض هاته الصفحة، يبدوا أنك تستعملين لارافيل، افتحي ملف app.blade.php واضيفي السطر التالي: @vite(['resources/css/app.css']) أيضا تأكدي من احتواء ملف app.css على التنسيقات اللازمة. تنسيقات tailwindcss مثلا: @tailwind base; @tailwind components; @tailwind utilities;
- 5 اجابة
-
- 1
-
من الصعب تشخيص المشكلة من ملف الجافاسكربت وحده، ولكن يرجح إلى أن هنالك مشكلة بتوصيف العنصر بالمعرف المناسب، فجافاسكربت لا تتعرف على أي عنصر يمتلك آي دي بالقيمة: serviceRequestForm تأكد من وجود عنصر استمارة form يمتلك هذا المعرف على نحو: <form id="serviceRequestForm" .. اعرف أكثر عن addEventListener:
- 2 اجابة
-
- 1
-
وعليكم السلام، نعم، إذا كنت تخطط لتشغيل تطبيق Nuxt.js SSR (Server-Side Rendering) على خادم Ubuntu، فإنه من المستحسن تثبيت خادم وكيل عكسي يمكنه التعامل مع طلبات المستخدمين وتوجيهها إلى تطبيقك الذي يعمل على الخادم. وسيكون nginx خيارا جيدا نعم. فيما يلي تكوين nginx الخاص بتطبيق Nuxtjs المستعمل عادة: server { listen 80; server_name domain_name.test; location / { proxy_pass http://localhost:3000; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection 'upgrade'; proxy_set_header Host $host; proxy_cache_bypass $http_upgrade; } } استبدل domain_name.test بدومينك الكامل. طبعا لا تنسى تشغيل npm run start لخادم node الخاص بالتطبيق، فـ nginx ستقوم بإرسال الطلبات إليه وتحويلها إلى العميل كخادم وكيل، لتدعم فكرة التصيير على الخادم server side rendering بهاته المقاربة. بالنسبة لشهادة الأمان SSL، فإن تثبيت شهادة SSL يعتبر أمرًا جيدًا ومهمًا لتأمين اتصالات موقعك. لك كامل الحرية في ذلك، ولكنه شيء منصوح به بطبيعة الحال.
- 1 جواب
-
- 1
-
رغم أن الفكرة في حد ذاتها جيدة وعملية ولا بأس بها، إلا أن الآن قد لا يكون مناسبا لمشاهدتها. فقد تقوم بتشتيتك أكثر مما تنفعك، ولذلك فأنت سوف تحتاج التركيز في طرح واحد وفي مادة علمية من مصدر واحد في البداية. ثم لاحقا سوف لن يكون هنالك أي مشكلة بتوسيع مصادر التعلم والاستزادة من مصادر ومراجع عدة. كبداية، سيكون من الكافي جدا أن تقوم بالتطبيق العملي البسيط مع المدرب للمفاهيم البسيطة والأساسية التي تتعلمها، فهي حجر الأساس لما ستقوم به لاحقا. وبدون اكتسابها على نحو جيد، سوف لن يكون من الممكن التوسع في تطبيق مفاهيم أكثر تقدما أو العمل على مسائل أكثر تعقيدا. بالمختصر: اجعل بدايتك متواضعة، وتوسع لاحقا.
-
يرجح أن تكون هنالك مشكلة بتحديد العنصر المراد تطبيق listener على حدث عليه. ولذلك تأكد من استعمال محدد DOM صحيح. const el = document.getElementById('myItem'); el.addEventListener('click', function(){ console.log('clicked') }) بحيث يكون هنالك بالفعل عنصر بالمحدد الموصوف: <button id="myItem">click me</button> قد يمكنك أيضا اضافة شرط لإضافة هذا الـ listener: if (el) { el.addEventListener('click', function(){}); }
-
جربي مراسلة الدعم.
-
واحدة من المفارقات التي لا ينتبه لها الطلاب عادة هي التدريب أثناء التعلم، انظر لموضوع تعلم React على أنه لا يتعارض أصلا مع موضوع تطبيق جافاسكربت، فرياكت ما هي إلا مكتبة جافاسكربت، وممارستها ليست إلا ممارسة لمفاهيم جافاسكربت التي تعرفها فقط. فضلا عن أن مكتبات وأطر عمل جافاسكرربت تحسن من مستواك في فهم اللغة نفسها. نفس الشيء بالنسبة لمهارات حل المشكلات وغيرها، فأنت ستتعلمها هي الأخرى بتطبيقك لمثل هاته المفاهيم. ولذلك فإن الخطوة التالية هي مواصلة المسير، والتعرض للمزيد من المادة العلمية مع ممارستها وتطبيقها. ثالثا، لا يوجد أي شيء لا أهمية منه. كل ما تعلمته ستحتاجه في جزئية ما، والإلمام به سيعطيك بعد نظر وسعة إطلاع تساعدك في حل المشكلات واقتباس الحلول وايجادها. ولذلك لا تستهن بأي ما تتعلمه وانظر لكل ذلك على أنه مهم سيأتي وقته.
- 4 اجابة
-
- 2
-
حسن انتظري قليلا فقط، وسيظهر لك زر دوراتي. قد يأخذ ذلك بعض الوقت،
-
هل وصلك الايميل؟
-
بعد اشتراكك في دورة ما، انتظر وصول بريد الكتروني يحمل تأكيدا لعملية الدفع، ثم ترقب ظهور زر "دوراتي" في أعلى الصفحة في قائمة الصفحات: قد يأخذ ذلك بعض الوقت، في حالة تعذر ذلك، يمكنك التواصل مع الدعم بشأن المشكلة.
-
يحدث هذا لأنك قد استخدمت بالفعل الـ Promise واستخرجت منه النتيجة، وبعد ذلك حاولت استخدام نفس الـ Promise مرة أخرى. لذلك، يفترض أن تنشئ Promises جديدة إذا كنت تريد استخدامها مرات أخرى. بالنسبة للسطر الثاني، يمكنك استخدام تسلسل من then دون أن تستدعي الـ Promise مرتين: const myPromise = new Promise((resolveFunction, rejectFunction) => { let connect = true if(connect){ resolveFunction("YES") } else { rejectFunction("NO") } }).then( (resolveValue) => { console.log(`${resolveValue}, Done`) return resolveValue; // إعادة القيمة للاستخدام في الـ then التالي }, (rejectValue) => console.log(`${rejectValue}, Not Done`) ).then( (resolveValue) => console.log(`${resolveValue}, Done`), (rejectValue) => console.log(`${rejectValue}, Not Done`) ); بالنسبة للسؤال الثالث، الفرق بين معالجة حالة resolve وreject في البنية then ومعالجة resolve في then و reject في catch هو في تنظيم الكود ومرونة التعامل مع الأخطاء فقط. ولذلك، من الأفضل استخدام catch لمعالجة حالات الأخطاء الخاصة بالـ Promise، حيث يسهل تمييز الأخطاء وإدارتها بشكل منفصل.
- 1 جواب
-
- 1
-
طبعا يمكنك رفض العمل على المشاريع المشبوهة بشكل قطعي وحل المشكلة، رغم أن أغلب شركات البرمجة العربية والمسلمة لا تستقبل مشاريعا من هذا النوع أساسا. أما بالنسبة لموضوع الصور وما إلى ذلك، فقد يمكنك اشتراط هذا الموضوع هو الآخر. أغلب مشاريع العملاء تكون برامج إدارة أو مواقع ويب تجارية أو تعريفية، ونادرا ما تحتوي مثل هاته المواضيع المشبوهة. ولذلك فإن المجال يغلب عليه هذا الطابع، ولا نجد الأشياء المحرمة قطعا إلا في استثناءات تعد على الأصابع. استمر ولا تقلق بشأن الموضوع، سوف يمكنك التحوط من كل ما هو محرم بأساليب شتى.
- 2 اجابة
-
- 1