دروس PHP

PHP الرئيسية مقدمة PHP تثبيت PHP بناء جملة PHP تعليقات PHP متغيرات PHP PHP صدى / طباعة أنواع بيانات PHP سلاسل PHP أرقام PHP PHP الرياضيات ثوابت PHP مشغلي PHP PHP إذا ... آخر ... Elseif مفتاح PHP حلقات PHP وظائف PHP مصفوفات PHP PHP Superglobals PHP RegEx

نماذج PHP

معالجة نموذج PHP التحقق من صحة نموذج PHP نموذج PHP مطلوب نموذج PHP URL / البريد الإلكتروني اكتمل نموذج PHP

PHP متقدم

تاريخ ووقت PHP تضمين PHP معالجة ملفات PHP فتح / قراءة ملف PHP إنشاء / كتابة ملف PHP تحميل ملف PHP ملفات تعريف الارتباط PHP جلسات PHP مرشحات PHP مرشحات PHP متقدم وظائف رد الاتصال PHP PHP JSON استثناءات PHP

PHP OOP

PHP ما هو OOP فئات / كائنات PHP منشئ PHP مدمر PHP معدِّلات الوصول إلى PHP الوراثة PHP ثوابت PHP فئات مجردة PHP واجهات PHP سمات PHP طرق PHP الثابتة خصائص PHP الثابتة مساحات أسماء PHP PHP تكرارات

قاعدة بيانات MySQL

قاعدة بيانات MySQL اتصال MySQL إنشاء قاعدة بيانات MySQL إنشاء جدول MySQL MySQL إدراج البيانات MySQL الحصول على آخر معرف إدراج عدة MySQL تم تجهيز MySQL MySQL حدد البيانات MySQL أين ترتيب MySQL حسب MySQL حذف البيانات تحديث بيانات MySQL بيانات MySQL المحدودة

لغة PHP XML

موزعي PHP XML محلل PHP SimpleXML PHP SimpleXML - احصل على PHP XML Expat PHP XML DOM

PHP - أجاكس

مقدمة أجاكس أجاكس بي إتش بي قاعدة بيانات أجاكس AJAX XML بحث أجاكس لايف استطلاع أجاكس

أمثلة PHP

أمثلة PHP مترجم PHP اختبار PHP تمارين PHP شهادة PHP

مرجع PHP

نظرة عامة على PHP صفيف PHP تقويم PHP تاريخ PHP دليل PHP خطأ PHP استثناء PHP نظام ملفات PHP مرشح PHP PHP FTP PHP JSON كلمات PHP PHP Libxml PHP Mail PHP الرياضيات متفرقات PHP PHP MySQLi شبكة PHP التحكم في إخراج PHP PHP RegEx PHP SimpleXML PHP ستريم سلسلة PHP معالجة متغيرة PHP محلل PHP XML PHP Zip المناطق الزمنية PHP

مثال PHP - بحث AJAX المباشر


يمكن استخدام AJAX لإنشاء عمليات بحث أكثر سهولة في الاستخدام وتفاعلية.


بحث أجاكس لايف

سيوضح المثال التالي بحثًا مباشرًا ، حيث تحصل على نتائج البحث أثناء الكتابة.

البحث المباشر له فوائد عديدة مقارنة بالبحث التقليدي:

  • تظهر النتائج أثناء الكتابة
  • النتائج ضيقة مع استمرار الكتابة
  • إذا أصبحت النتائج ضيقة جدًا ، فقم بإزالة الأحرف لرؤية نتيجة أوسع

ابحث عن صفحة W3Schools في حقل الإدخال أدناه:

تم العثور على النتائج في المثال أعلاه في ملف XML ( links.xml ). لجعل هذا المثال صغيرًا وبسيطًا ، تتوفر ست نتائج فقط.


شرح المثال - صفحة HTML

عندما يكتب المستخدم حرفًا في حقل الإدخال أعلاه ، يتم تنفيذ الوظيفة "showResult ()". يتم تشغيل الوظيفة بواسطة حدث "onkeyup":

<html>
<head>
<script>
function showResult(str) {
  if (str.length==0) {
    document.getElementById("livesearch").innerHTML="";
    document.getElementById("livesearch").style.border="0px";
    return;
  }
  var xmlhttp=new XMLHttpRequest();
  xmlhttp.onreadystatechange=function() {
    if (this.readyState==4 && this.status==200) {
      document.getElementById("livesearch").innerHTML=this.responseText;
      document.getElementById("livesearch").style.border="1px solid #A5ACB2";
    }
  }
  xmlhttp.open("GET","livesearch.php?q="+str,true);
  xmlhttp.send();
}
</script>
</head>
<body>

<form>
<input type="text" size="30" onkeyup="showResult(this.value)">
<div id="livesearch"></div>
</form>

</body>
</html>

شرح كود المصدر:

إذا كان حقل الإدخال فارغًا (str.length == 0) ، تقوم الوظيفة بمسح محتوى العنصر النائب lifearch وإنهاء الوظيفة.

إذا لم يكن حقل الإدخال فارغًا ، تقوم الوظيفة showResult () بتنفيذ ما يلي:

  • قم بإنشاء كائن XMLHttpRequest
  • قم بإنشاء الوظيفة التي سيتم تنفيذها عندما تكون استجابة الخادم جاهزة
  • أرسل الطلب إلى ملف موجود على الخادم
  • لاحظ أنه تمت إضافة المعلمة (q) إلى عنوان URL (مع محتوى حقل الإدخال)


ملف PHP

الصفحة الموجودة على الخادم التي تم استدعاؤها بواسطة JavaScript أعلاه هي ملف PHP يسمى "lifearch.php".

يبحث الكود المصدري في "lifearch.php" في ملف XML عن العناوين المطابقة لسلسلة البحث ويعيد النتيجة:

<?php
$xmlDoc=new DOMDocument();
$xmlDoc->load("links.xml");

$x=$xmlDoc->getElementsByTagName('link');

//get the q parameter from URL
$q=$_GET["q"];

//lookup all links from the xml file if length of q>0
if (strlen($q)>0) {
  $hint="";
  for($i=0; $i<($x->length); $i++) {
    $y=$x->item($i)->getElementsByTagName('title');
    $z=$x->item($i)->getElementsByTagName('url');
    if ($y->item(0)->nodeType==1) {
      //find a link matching the search text
      if (stristr($y->item(0)->childNodes->item(0)->nodeValue,$q)) {
        if ($hint=="") {
          $hint="<a href='" .
          $z->item(0)->childNodes->item(0)->nodeValue .
          "' target='_blank'>" .
          $y->item(0)->childNodes->item(0)->nodeValue . "</a>";
        } else {
          $hint=$hint . "<br /><a href='" .
          $z->item(0)->childNodes->item(0)->nodeValue .
          "' target='_blank'>" .
          $y->item(0)->childNodes->item(0)->nodeValue . "</a>";
        }
      }
    }
  }
}

// Set output to "no suggestion" if no hint was found
// or to the correct values
if ($hint=="") {
  $response="no suggestion";
} else {
  $response=$hint;
}

//output the response
echo $response;
?>

إذا تم إرسال أي نص من JavaScript (strlen ($ q)> 0) ، فسيحدث ما يلي:

  • قم بتحميل ملف XML في كائن XML DOM جديد
  • قم بإجراء تكرار عبر جميع عناصر <title> للعثور على مطابقات من النص المرسل من JavaScript
  • يضبط عنوان url والعنوان الصحيحين في المتغير "$ response". إذا تم العثور على أكثر من تطابق ، تتم إضافة جميع التطابقات إلى المتغير
  • إذا لم يتم العثور على مطابقات ، يتم تعيين متغير الاستجابة $ على "لا يوجد اقتراح"