-
المساهمات
1588 -
تاريخ الانضمام
-
تاريخ آخر زيارة
-
عدد الأيام التي تصدر بها
1
نوع المحتوى
ريادة الأعمال
البرمجة
التصميم
DevOps
التسويق والمبيعات
العمل الحر
البرامج والتطبيقات
آخر التحديثات
قصص نجاح
أسئلة وأجوبة
كتب
دورات
كل منشورات العضو Khaled Osama3
-
لصنع لوحة توزيع لمفاتيح التشفير باستخدام PHP وMySQL، ستحتاج أولًا إلى القدرة الفنية على البرمجة ومعرفة بكيفية إدارة البيانات داخل قاعدة البيانات. ولكن، عندما يتعلق الأمر بجلب مفاتيح فك التشفير وإرسالها إلى المشترك، هناك عدة نقاط يجب التفكير فيها: 1. الحصول على المفاتيح: يجب أن تكون لديك طريقة قانونية للحصول على مفاتيح فك التشفير. غالبًا ما تكون هذه المفاتيح ملكًا للموفرين الرسميين للخدمة وتستخدم لضمان أن الأشخاص الذين يدفعون مقابل الخدمة فقط هم من يمكنهم الوصول إليها. 2. إرسال المفاتيح: إذا كان لديك وصول قانوني إلى المفاتيح، فسيكون من الضروري تطوير نظام يمكن المشتركين من الوصول إلى هذه المفاتيح بطريقة آمنة وموثوقة. هذا قد يشمل التحقق من صحة المشتركين وتأكيد أن لديهم اشتراكا صالحا قبل إرسال المفاتيح. 3. التأمين والحماية: يجب أن يكون النظام الذي تطوره آمنًا لمنع الوصول غير المصرح به. هذا يشمل تأمين الاتصالات عبر الإنترنت باستخدام تشفير SSL/TLS، وتخزين المفاتيح بطريقة آمنة، وتطبيق أفضل الممارسات لأمان الويب. 4. الاستضافة: يجب أن تستضيف نظامك على خادم يمكنه التعامل مع الاتصالات المتزامنة ولديه وقت تشغيل عالي لضمان استمرارية الخدمة. 5. القانونية: وكما ذكرت سابقًا، يجب التأكد من أن كل جانب من جوانب النظام يتوافق مع القوانين المحلية والدولية، خاصة فيما يتعلق بحقوق الطبع والنشر والخصوصية.
- 5 اجابة
-
- 1
-
هذا يحدث لأن الصورة لا تتكيف مع أحجام الشاشات المختلفة بشكل تلقائي. يمكنك استخدام background-size: cover;: - هذه الخاصية تضمن أن الخلفية ستغطي كامل المساحة المتاحة دون أن تفقد نسبها الأصلية. - تجعل الصورة تمتد لتغطية العنصر بالكامل، مع الحفاظ على نسب العرض إلى الارتفاع. او استخدام background-size: contain;: - تضمن هذه الخاصية ظهور الصورة بأكملها، لكنها قد تترك بعض المساحات الفارغة حول الصورة إذا كانت نسب أبعاد الصورة مختلفة عن نسب أبعاد العنصر. جعل التصميم متجاوبا مع أحجام شاشات مختلفة باستخدام @media queries: - يمكنك تعديل تصميمك ليناسب أحجام شاشات مختلفة، مثل الأجهزة اللوحية والهواتف المحمولة، بتحديد أنماط CSS مختلفة لأحجام شاشات محددة. مثال على كود CSS: body { background-image: url('path-to-your-image.jpg'); background-size: cover; /* أو استخدم contain حسب الحاجة */ background-position: center; /* لضمان توسيط الصورة */ } /* تعديلات للشاشات الصغيرة */ @media screen and (max-width: 992px) { /* تعديلات لأجهزة اللوحي */ } @media screen and (max-width: 768px) { /* تعديلات لشاشات أصغر */ } @media screen and (max-width: 640px) { /* تعديلات للهواتف الذكية */ } @media screen and (max-width: 320px) { /* تعديلات لشاشات الهواتف الصغيرة جدًا */ } - background-size: cover; تستخدم لضمان تغطية الخلفية لكامل المساحة المتاحة. - background-size: contain; تضمن رؤية الصورة بأكملها على الشاشة. - @media queries تستخدم لجعل الصفحة تتجاوب مع أحجام شاشات مختلفة، بتطبيق أنماط CSS مختلفة تبعا لحجم الشاشة.
-
في Python، تتوفر العديد من المكتبات والأدوات التي تسمح بالتعامل مع مصادر مختلفة للبيانات مثل جداول بيانات Excel، جداول بيانات Google، مستندات Word، ملفات CSV و JSON، بالإضافة إلى قواعد البيانات،بشكل عام، فإن استخدام Python للتعامل مع جميع هذه المصادر للبيانات يوفر مرونة وقوة في تطوير التطبيقات، ويسمح بالتفاعل مع مجموعة متنوعة من المصادر بسهولة وفعالية. و الفوائد من التعامل مع جداول بيانات جوجل والمستندات تعتمد على الاحتياجات الخاصة بالمشروع أو التطبيق. قد تحتاج إلى استيراد بيانات من جداول جوجل لتحليلها أو عرضها بطريقة معينة، أو ربما تحتاج إلى إنشاء تقارير تفصيلية في مستندات Word استنادًا إلى بيانات معينة. هذه الأدوات ليست مجرد إضافات في اللغة، بل توفر واجهات للتفاعل مع مصادر بيانات محددة. وهذه بعض الأمثلة التى من الممكن ان تيجب عن سؤالك: التعامل مع جداول بيانات جوجل والمستندات: يمكن للتطبيقات والسكربتات المكتوبة بلغة Python الوصول إلى جداول بيانات Google والمستندات وتعديلها باستخدام Google APIs. يعتبر هذا مفيدًا للتفاعل مع بيانات Google Drive ومشاركتها مع الآخرين بشكل مباشر من التطبيقات التي تم إنشاؤها بواسطة Python. التعامل مع المستندات ورد: في بعض الحالات، قد تحتاج تطبيقات Python إلى إنشاء أو تحرير مستندات Word بشكل ديناميكي، مثل إنشاء تقارير أو وثائق مخصصة تستند إلى البيانات المتاحة. بالتالي، فإن التعامل مع مستندات Word يمكن أن يكون مفيدًا للتطبيقات القائمة على Python.
- 3 اجابة
-
- 1
-
لن تحتاج إلى أن تعرف ال software architecture إذا كنت تتعلم تعلم الآلة فليس له استخدام فى تعلم الآلة عمتا.
- 4 اجابة
-
- 1
-
عليكم السلام، العمارة البرمجية (Software Architecture) هي الهيكلية الأساسية لنظام البرمجيات، تحدد كيفية تنظيم الأنظمة البرمجية وتفاعل مكوناتها مع بعضها. تركز على تحديد المكونات الرئيسية للنظام، والعلاقات بينها، وكيفية تنظيمها لتحقيق أهداف الأعمال وتحقيق الأداء والموثوقية. وتهدف إلى تحسين جودة النظام البرمجي وقابليته للصيانة والتوسع. ووتتكون من عدة عناصر وهى : المكونات أو (Components): هي الأجزاء البنائية للنظام مثل الوحدات، والمكتبات، والخدمات. تتعامل المكونات مع البيانات وتنفذ الوظائف المحددة. الاتصالات أو (Communications): تحدد كيفية تبادل المكونات المعلومات والبيانات مع بعضها البعض، يتم ذلك عادة من خلال واجهات محددة وبروتوكولات اتصال معينة. الهياكل أو (Structures): توضح كيفية تنظيم المكونات داخل النظام والعلاقات بينها، مثل الهياكل الطبقية والهياكل الأساسية والهياكل المتجهة. السياسات أو (Policies): تعرف القواعد والتوجيهات التي تحكم سلوك النظام، مثل قواعد إدارة الذاكرة أو قواعد الوصول إلى البيانات المبادئ التوجيهية أو (Guiding Principles): هي المبادئ والقواعد التي توجه عملية تصميم العمارة البرمجية مثل فصل القلق وإعادة الاستخدام والتوسعية.
- 4 اجابة
-
- 1
-
وعليكم السلام ورحمة الله، من وجهة نظري أنه من الأفضل أن تتعمق أكثر في رياكت قبل الانتقال لـ Node.js. وذلك لعدة أسباب: رياكت مكون أساسي يجب فهمه جيدا قبل الانتقال لمراحل أعمق. ستستطيع بناء تطبيقات واقعية برياكت وتطبيق ما تعلمته عمليا. سيكون لديك خلفية أفضل عن جانب الويب قبل دخول الجانب الخادم. ستتمكن من الاستفادة مما تعلمته لاحقا عند دراسة Node.js قد تحتاج تعزيز بعض المفاهيم بالتطبيق قبل الانتقال. يجب التمكن من React ومجالاتها المتقدمة (مثل إدارة الحالة مع Redux أو MobX، Context API، Hooks، وغيرها) سيعزز قدراتك في تطوير الواجهات الأمامية. نصيحتي بالتركيز أكثر على رياكت الآن عبر إنشاء مشاريع حقيقية، ثم بعدها البدء في Node.js. سيكون التعلم أكثر استفادة وترابطا.
- 3 اجابة
-
- 2
-
لعمل ال activity diagram يمكنك استخدام برنامج مثل draw.io أو lucidChart هذه أحسن البرامج اللتى يمكن ان تستخدميها لعمل ال Activity Daigram. وهذا بعض التوضيحات اللتى سوف تساعدك على بناء Activity Diagram ل subject enrolment : تصفح المواد المتاحة: الطالب سيقوم بفتح قائمة المواد المتاحة في النظام، حيث يمكنه استعراض قائمة بجميع المواد التى يمكنه التسجيل بها في الفصل الدراسي الحالي. البحث عن مادة محددة: إذا كان الطالب يبحث عن مادة معينة، فإنه يمكنه استخدام خاصية البحث في النظام للعثور على المادة التي يرغب في تسجيلها. إضافة المادة إلى الجدول الزمني: بعد اختيار المادة التي يرغب في تسجيلها، يقوم الطالب بإضافتها إلى جدوله الزمني في النظام، محددا الفترات الزمنية التي يرغب في حضور المحاضرات أو الفصول الدراسية. تأكيد التسجيل: بمجرد اكتمال جدول الطالب، سيقوم بتأكيد التسجيل، ما يعني أنه قد اختار المواد وحدد الفترات الزمنية المناسبة لها. فحص توافر الأقسام: بعد تأكيد التسجيل، سيقوم النظام بفحص توافر الأقسام للمواد التي اختارها الطالب، للتأكد مما إذا كان بإمكان الطالب الالتحاق بالفصول الدراسية المطلوبة أم لا. تأكيد أو إلغاء التسجيل: استنادًا إلى نتائج الفحص، سيقوم النظام بتأكيد تسجيل الطالب في الأقسام المتاحة، أو سيقوم بإلغاء التسجيل في الأقسام التي لا تتوفر فيها مقاعد شاغرة
-
يوجد مشكلة عند عرض النص العربي في عنوان الرسالة بسبب أن بروتوكول البريد الإلكتروني لا يدعم ترميز النصوص غير الإنجليزية بشكل افتراضي. لحل هذه المشكلة يجب تعيين ترميز النص إلى UTF-8 قبل تعيين عنوان الرسالة كالآتي: $mail->CharSet = 'UTF-8'; $mail->setFrom('test@gmail.com', 'موقع كورة'); أو يمكن تعيين ترميز النص عند بداية إنشاء المكتبة باستخدام الخاصية CharSet: $mail = new PHPMailer(true); $mail->CharSet = 'UTF-8'; $mail->setFrom('test@gmail.com', 'موقع كورة');
-
Express.js و Next.js ليسا بالضرورة متضادين، بل يمكن استخدام كلاهما معا في بعض الحالات، ولكن يتميز كل منهما فى مجالات استخدام مختلفة. Express.js: Express.js هو إطار عمل لجافا سكريبت مبني على Node.js ، ويستخدم لبناء تطبيقات الويب وواجهات البرمجة،يعتبر Express.js مرن ويمنح المطورين الحرية في تنظيم الطرق والمنطق الخلفي او كما يطلق عليه back-end لتطبيقاتهم. Next.js: Next.js هو إطار عمل لجافا سكريبت و React مصمم خصيصًا لبناء تطبيقات الويب، ويوفر ميزات مثل التقدم التدريجي وتوليد الصفحات الثابتة والتحميل التلقائى للبيانات . يستخدم Next.js عادة لتطوير تطبيقات الويب الديناميكية والمتقدمة. الاختيار بين استخدام Express.js و Next.js يعتمد على متطلبات مشروعك ومستوى التكامل مع React و Electron.js. إذا كنت تبني تطبيق ويب تفاعلي متقدم مع React، فمن الأفضل استخدام Next.js حيث يتمتع بميزات مدمجة تجعل تطوير التطبيقات الديناميكية أكثر سهولة. إذا كنت بحاجة إلى مرونة كبيرة في تنظيم طرق الخادم والمنطق الخلفي، فقد تفضل استخدام Express.js. يمكن استخدام كل من Express.js و Next.js في تطبيق Electron.js إذا كنت ترغب في استخدام Node.js في الجزء الخلفي من التطبيق بينما يمكنك استخدام Express.js لإنشاء خادم و API للتفاعل مع قاعدة البيانات أو الخدمات الخارجية، بينما يمكنك استخدام Next.js لبناء واجهة المستخدم وتحميل الصفحات الديناميكية. باختصار اختيار الإطار المناسب يعتمد على احتياجات مشروعك ومستوى التكامل المطلوب مع الأدوات الأخرى التي تستخدمها.
-
نعم في هذا المثال : $str = 'abcdefa'; echo strpos($str, 'cd'); النتيجة ستكون 2. حيث ان strpos() تقوم بالبحث عن سلسلة 'cd' في سلسلة 'abcdefa'. تم العثور على 'cd' في الموقع رقم 2 بداية من اليسار. تحسب المواقع أو الأحرف المكون للسلسلة بداية من 0 وليس 1. لذلك، عندما تعيد الدالة القيمة 2، فهي تعني أن أول ظهور للسلسلة المحددة ('cd') يبدأ من الموقع 2 داخل السلسلة المعطاة ('abcdefa'). إليك كيف يتم العد: - a (الموقع 0) - b (الموقع 1) - c (الموقع 2) - d (الموقع 3) - e (الموقع 4) - f (الموقع 5) - a (الموقع 6) لذا فإن النتيجة تعطينا الموقع رقم 2 حيث تم العثور على 'cd' لان موقع بداية سلسلة الحروف 'cd' حسب ترتيبها في السلسلة الأصلية، وليس عدد الحروف.
- 2 اجابة
-
- 1
-
هذا الكود ينقسم الي دالتين داخل الcontroller، وهما validator و create. هذه الطرقتين تستخدم في عملية تسجيل المستخدمين في الموقع. لنبدا نشرح الدالة validator الطريقة validator تستخدم للتحقق من صحة (validation) البيانات المدخلة من قبل المستخدم عند التسجيل. تستخدم Laravel Validator::make لإنشاء وتشغيل عملية التحقق من الصحة. 'name' => ['required', 'string', 'max:255'] هذا حقل الاسم يجب أن يكون مطلوبا، وايضا أن يكون نوع البيانات نصيا، وألا يتجاوز الطول 255 حرفا. 'email' => ['required', 'string', 'email', 'max:255', 'unique:users'] هذا حقل البريد الإلكتروني يجب أن يكون مطلوبا، نصيا، صالحا كعنوان بريد إلكتروني، وألا يتجاوز الطول 255 حرفا، وأن يكون فريدا في جدول المستخدمين (غير مكرر). 'password' => ['required', 'string', 'min:8', 'confirmed'] هذا حقل كلمة المرور يجب أن يكون مطلوبا، نصيا، وألا يقل طوله عن 8 أحرف، وأن يكون متطابقًا مع حقل التأكيد (أي يجب على المستخدم إدخال كلمة المرور مرتين للتأكيد). لنبدا نشرح الدالة create لقد تحققنا من صحة البيانات وكل شئ علي ما يرام، الان نستخدم الدالة create لإنشاء حساب جديد للمستخدم في قاعدة البيانات. User::create([...]) هذه الدالة تستدعي الدالة create على موديل User، والتي تستخدم البيانات المقدمة لإنشاء سجل جديد في قاعدة البيانات. Hash::make($data['password']) تستخدم لتشفير كلمة المرور قبل تخزينها في قاعدة البيانات لأسباب أمنية. في النهاية، يتم إرجاع حساب المستخدم الجديد بعد إنشائه في قاعدة البيانات، وهذا سيكون مهمًا للتحقق من أن العملية تمت بنجاح ولاتاحة الاستخدام للمستخدم الجديد أو لإجراء عمليات إضافية مثل إرسال رسالة ترحيب او ادخاله علي صفحه البروفايل الخاصه به.
- 1 جواب
-
- 1
-
الوراثة المتعددة والكونستركتور هما مفهومان مهمان في البرمجة الموجهة للكائنات (OOP). ساشرح كل واحد ببساطة ووضوح. الوراثة المتعددة الوراثة المتعددة هي ميزة تسمح لكلاس (صنف) واحد بوراثة ميزات أو خصائص من أكثر من كلاس واحد. يمكنك تخيل الوراثة المتعددة مثل طفل يرث صفات من والده ووالدته معا. هذا يجعل الكود أكثر قابلية لإعادة الاستخدام وتنظيما لأنك تستطيع جمع خصائص ووظائف من كلاسات مختلفة في كلاس واحد. مثال: لنفترض أن لدينا كلاس للطائر وكلاس للسباح، يمكننا إنشاء كلاس جديد يسمى "Duck" يرث الخصائص من كلا الكلاسين لأن البطة تستطيع الطيران والسباحة. ومع ذلك، تجدر الإشارة إلى أن بعض لغات البرمجة مثل Java لا تدعم الوراثة المتعددة مباشرة بسبب تعقيدات مثل "مشكلة الماس"، حيث يمكن أن يحصل الكلاس الفرعي على نفس الطريقة من كلاسين أساسيين مختلفين، مما يؤدي إلى الارتباك حول أي طريقة يجب أن تستخدم. في هذه الحالات، يمكن استخدام واجهات(interfaces) أو تكوين بدلا من الوراثة. الكونستركتور في OOP الكونستركتور هو طريقة خاصة داخل الكلاس تدعى تلقائيًا عند إنشاء كائن (instance) من ذلك الكلاس. يستخدم الكونستركتور عادة لتهيئة الكائن، مثل تعيين القيم الابتدائية لمتغيرات الكلاس. مثال: إذا كان لدينا كلاس يمثل كتاب، فقد يحتوي الكونستركتور على معلمات لعنوان الكتاب واسم المؤلف. عند إنشاء كائن جديد من الكلاس، يمكنك تحديد هذه البيانات مباشرة. class Book { String title; String author; // هذا هو الكونستركتور Book(String title, String author) { this.title = title; this.author = author; } } في البرمجة الموجهة للكائنات، يعتبر استخدام الكونستركتورات طريقة فعالة لضمان أن الكائن يتم تهيئته بحالة صالحة للاستخدام مباشرة بعد إنشائه.
-
لا يمكنك تغيير ال package name حتى ولو كان معك ال key Store الخاص بالتطبيق ، واذا اردت تغييرها عليك برفع التطبيق مرة اخرى كأنه تطبيق جديد ، حلك ان تقوم بعمل تحديث للتطبيق بنفس اسم ال package name او اما ان تقوم باعادة رفع التطبيق من جديد ونعم عندها سيكون تحميلات 0 وتعليقات 0 وتقيم 0 ...الخ وليس هناك نفع لل key store فى هذه الحالة ، حتى شركة facebook او تويتر لا تستطيع تغيير ال package name.
- 4 اجابة
-
- 1
-
لا ليس بالضرورة أن يكون الجهاز الذي عليه ملفات الموقع تعمل 24 ساعة لكي يعمل الموقع. الطريقة الصحيحة هي تحميل الموقع على خادم ويب (Web Server) يعمل على مدار 24 ساعة. الموقع الشخصي يمكن تحميله على جهاز المبرمج دون حاجة لخادم دائم. المواقع التجارية أو الهامة يفضل تحميلها على خادم متخصص يعمل 24/7. عند إغلاق جهاز المبرمج لن يتمكن الزوار من الوصول للموقع. الخوادم المتخصصة مثل AWS, GCP, Azure توفر بيئة احترافية 24/7. فالموقع يعتبر "دائم" فقط إذا كان محملاً على خادم يعمل 24 ساعة، أما الجهاز الشخصي فلا يضمن الوصول الدائم.
- 4 اجابة
-
- 1
-
نعم، المحتوى المقدم في هذا المقال لا يزال صالحًا وفعالًا لاستخدامه مع لارافيل 10. على الرغم من أن بعض التفاصيل التقنية قد تكون قد تغيرت قليلاً منذ ذلك الحين، إلا أن المبادئ الأساسية لإدارة الصور في لارافيل تظل نفسها. يغطي المقال المواضيع الأساسية مثل إنشاء النموذج والهجرة والمتحكم وإنشاء المجلدات لتخزين الصور وعمل عرض إنشاء لرفع الصور هذه الأشياء لا تزال سارية المفعول في لارافيل 10. ربما تتغير بعض التفاصيل الثانوية مثل إصدارات الحزم أو طرق الكتابة، ولكن المبادئ الأساسية لا تزال نفسها. الحزم مثل Intervention Image وlaravelcollective/html تتم صيانتها بشكل منفصل عن Laravel نفسه، لذا يجب تحديثها مع إصدار Laravel 10. بشكل عام، يجب أن تكون متوافقة طالما تم تحديثها بشكل دوري لدعم الإصدارات الجديدة من Laravel. ولكن يجب الرجوع إلى الوثائق الرسمية لـ Laravel 10 للتأكد من أية تغييرات في ممارسات أفضل أو ميزات جديدة متوفرة في Laravel 10. لذلك يمكنك بالتأكيد استخدام هذا المقال لبناء ميزة إدارة الصور في مشروع لارافيل 10 خاص بك.
-
يمكنك بسهولة القيام بذلك باستخدام خدمة اختصار الروابط على موقع بلوجر وإعداد إعادة التوجيه للروابط المختصرة إلى الروابط الأصلية أو أي روابط ترغب في توجيهها إليها. وهذه بعض الخطوات اللى ممكن تستعين بيها للقيام يهذه المهمة: استخدام خدمة اختصار الروابط على بلوجر: يمكنك البحث عن خدمة اختصار الروابط على بلوجر أو استخدام أي امتداد أو خدمة توفر هذه الخدمة. يمكنك إضافة روابطك الأصلية والمختصرة على هذه الخدمة. إنشاء روابط مختصرة: قم بإنشاء روابط مختصرة باستخدام خدمة اختصار الروابط. عندما يتم النقر على هذه الروابط المختصرة، ستتم إعادة التوجيه بشكل تلقائي إلى الروابط الأصلية. إعادة التوجيه إلى بلوجر: يمكنك تكوين إعادة التوجيه من الروابط المختصرة إلى بلوجر عن طريق تحديد عنوان URL لصفحة بلوجر الخاصة بك. هذا يمكن أن يتم عبر لوحة التحكم في بلوجر أو عبر الخدمة التي تستخدمها لإدارة روابطك. بهذه الطريقة، عندما يتم فتح الرابط المختصر، سيتم توجيه المستخدم بشكل تلقائي إلى صفحة بلوجر الخاصة بك، ومن ثم سيتم التوجيه من بلوجر إلى الرابط الأصلي الذي تم اختصاره.
- 7 اجابة
-
- 1
-
إذا كنت تستخدم قالب اختصار الروابط على ووردبريس، فيمكنك بسهولة استخدامه لإنشاء روابط مختصرة تعيد التوجيه إلى صفحات البلوجر أو أي روابط أخرى ترغب في تخزينها. في هذه الحالة، لا داعي لاستخدام بلوجر كخدمة لاختصار الروابط. بمجرد تثبيت وتفعيل قالب اختصار الروابط على موقع ووردبريس الخاص بك، يمكنك بسهولة إنشاء روابط مختصرة لأي عنوان URL تريده، سواء كان ذلك لصفحات بلوجر أو صفحات أخرى. عندما يتم النقر على الرابط المختصر، سيتم إعادة التوجيه بشكل تلقائي إلى العنوان URL الأصلي. لذا، بإمكانك استخدام ووردبريس لإدارة جميع روابطك، بما في ذلك الروابط التي تعيد التوجيه إلى صفحات بلوجر أو أي مواقع أخرى، دون الحاجة إلى استخدام بلوجر كخدمة لإنشاء الروابط المختصرة.
- 7 اجابة
-
- 1
-
عليكم السلام يمكنك بناء موقع لاختصار الروابط بأي منصة تطوير ويب تدعم البرمجة وقواعد البيانات. يمكنك استخدام بلوجر لإنشاء موقع لاختصار الروابط، ولكن ستحتاج إلى القيام ببعض البرمجة الخاصة وربما استخدام خدمات تخزين البيانات الخارجية(Cloud). من ناحية أخرى، ووردبريس هي منصة تدعم بناء مواقع لاختصار الروابط بشكل أسهل، حيث تتيح لك إمكانية استخدام الإضافات المتاحة في سوق الإضافات الخاص بـ WordPress لإنشاء موقع لاختصار الروابط بسرعة وسهولة دون الحاجة إلى البرمجة الخاصة. إذا كنت تفضل استخدام بلوجر، فيجب أن تكون على علم بأنك ستحتاج إلى القيام بالبرمجة الخاصة لإضافة وظيفة اختصار الروابط وتخزينها، كما ستحتاج إلى التعامل مع الاستضافة والتحكم في قاعدة البيانات بشكل مباشر. بالمقابل، إذا استخدمت ووردبريس، يمكنك الاعتماد على الإضافات المتاحة التي تقدم هذه الوظيفة بشكل مباشر، مما يجعل العملية أسهل وأكثر فعالية بدون الحاجة إلى البرمجة الخاصة.
- 7 اجابة
-
- 1
-
في تطوير البرمجيات، يُشير مصطلح "الإغلاق" (Closure) إلى مفهوم يسمح للدالة بالوصول إلى المتغيرات اللى محيطة بها حتى بعد الانتهاء من تنفيذها، يعتبر هذا مهمًا في اللغات التي تدعم التعريفات المتداخلة للدوال (nested functions)، حيث يمكن للدالة الداخلية (المحتواة داخل دالة أخرى) أن تستخدم المتغيرات المحيطة بها حتى بعد ما تخلص تنفيذ الدالة الخارجية. الإغلاق يحدث عندما تُنشئ دالة داخلية في نطاق (scope) دالة أخرى وتستخدم متغيرات من نطاق الدالة الخارجية. عندما يتم تنفيذ الدالة الداخلية، فإنها تحتفظ بإمكانية الوصول إلى المتغيرات التي كانت متاحة في النطاق الخارجي في وقت تعريفها. الإغلاق يمكن أن يكون ذا قيمة خاصة عند التعامل مع التعامل مع المعالجات الحدثية (Event Handling) أو عند استخدام دوال رد الاتصال (Callback Functions) حيث يمكن للإغلاق أن يحمل متغيرات معينة في الوقت الذي يتم استدعاء فيه. وهذا مثال للتوضيح JavaScript: function outerFunction() { let outerVariable = 'I am outer!'; function innerFunction() { console.log(outerVariable); // يمكن للدالة الداخلية استخدام outerVariable } return innerFunction; } let closureExample = outerFunction(); closureExample(); // الإغلاق يسمح للدالة الداخلية بالوصول إلى outerVariable حتى بعد انتهاء تنفيذ outerFunction. هذا المثال يظهر كيف يمكن للدالة الداخلية (innerFunction) في الداله الخارجية outerFunction أن تتمكن من الوصول إلى المتغير outerVariable حتى بعد انتهاء تنفيذ outerFunction.
-
أنه يعمل معى جيدا، وبيطلع نمعطى 5. لكن ما هو ال compiler الذى تستخدمه؟
- 4 اجابة
-
- 1
-
ارجو التوضيح اكثر متي يتم شطبها؟
-
الفرق الرئيسي بين كتابة الحلقات بأقواس منحنية وبدونها يكمن في نطاق جسم الحلقة وهذا مثال يوضح الفرق: مع الأقواس المنحنية: عند استخدام الأقواس المنحنية، تعرف بوضوح نطاق جسم الحلقة. يتيح لك هذا تضمين عدة بيانات داخل جسم الحلقة دون أي ابهام بشأن نطاقها. على سبيل المثال: for (int i = 0; i < 5; i++) { System.out.println("داخل الحلقة"); System.out.println("قيمة i هي: " + i); } بدون الأقواس المنحنية: إذا حذفت الأقواس المنحنية، فإن البيانات التالية ستعتبر جزءًا من جسم الحلقة. يمكن أن يؤدي هذا إلى الارتباك والأخطاء إذا كانت العديد من البيانات تهدف إلى كونها جزءًا من جسم الحلقة ولكنها ليست مضمنة في الأقواس المنحنية. على سبيل المثال: for (int i = 0; i < 5; i++) System.out.println("داخل الحلقة"); System.out.println("قيمة i هي: " + i); // هذه ليست جزءًا من جسم الحلقة في هذا المثال، تعتبر فقط البيانات System.out.println("داخل الحلقة"); جزءًا من جسم الحلقة، بينما البيانات System.out.println("قيمة i هي: " + i); خارج جسم الحلقة وسيتم تنفيذها مرة واحدة فقط بعد انتهاء الحلقة.
- 5 اجابة
-
- 1
-
ارسل الكود للتوضيح اكثر
- 5 اجابة
-
- 1
-
بهذه الطريقة يمكنك وضع اى اسم تريده مكان name c.execute("DELETE FROM names WHERE name = ?", (name,))
- 3 اجابة
-
- 1
-
هذا ما تحتاجه للقيام بهذه المهمة // تنفيذ استعلام SQL للحصول على القيمة القصوى ل SupplierID string query = "SELECT MAX(SupplierID) FROM TBL_SUPP"; // قم بتنفيذ الاستعلام هنا باستخدام مكتبة الوصول إلى قاعدة البيانات الخاصة بك // قم بتخزين النتيجة في متغير maxID int maxID = executeQueryAndGetMaxID(query); // قم بتعيين القيمة القصوى ل SupplierID + 1 في حقل txtSupplierID txtSupplierID.Text = (maxID + 1).ToString();