أحدث البرامج التعليمية وتطوير الشبكة
 

AJAX PHP مثال


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


AJAX PHP مثال

والمثال التالي شرح كيفية صفحة ويب يمكن الاتصال مع خادم الويب في حين أن النوع المستخدم الأحرف في حقل الإدخال:

مثال

Start typing a name in the input field below:

First name:

Suggestions:



وأوضح مثال

في المثال أعلاه، عندما يكتب المستخدم حرف في حقل الإدخال، وهي وظيفة تسمى "showHint()" يتم تنفيذه.

يتم تشغيل وظيفة من قبل onkeyup الحدث.

هنا هو رمز HTML:

مثال

<html>
<head>
<script>
function showHint(str) {
    if (str.length == 0) {
        document.getElementById("txtHint").innerHTML = "";
        return;
    } else {
        var xmlhttp = new XMLHttpRequest();
        xmlhttp.onreadystatechange = function() {
            if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
                document.getElementById("txtHint").innerHTML = xmlhttp.responseText;
            }
        };
        xmlhttp.open("GET", "gethint.php?q=" + str, true);
        xmlhttp.send();
    }
}
</script>
</head>
<body>

<p><b>Start typing a name in the input field below:</b></p>
<form>
First name: <input type="text" onkeyup="showHint(this.value)">
</form>
<p>Suggestions: <span id="txtHint"></span></p>
</body>
</html>
انها محاولة لنفسك »

كود التفسير:

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

ومع ذلك، إذا كان حقل الإدخال ليست فارغة، قم بما يلي:

  • إنشاء XMLHttpRequest كائن
  • إنشاء وظيفة ليتم تنفيذها عندما استجابة الملقم جاهزة
  • إرسال طلب قبالة لملف PHP (gethint.php) على الخادم
  • لاحظ أن q يضاف المعلمة gethint.php?q="+str
  • في str متغير يحمل محتوى حقل الإدخال

في ملف PHP - "gethint.php"

ملف PHP يتحقق مجموعة من الأسماء، وإرجاع المقابل name(s) إلى المتصفح:

<?php
// Array with names
$a[] = "Anna";
$a[] = "Brittany";
$a[] = "Cinderella";
$a[] = "Diana";
$a[] = "Eva";
$a[] = "Fiona";
$a[] = "Gunda";
$a[] = "Hege";
$a[] = "Inga";
$a[] = "Johanna";
$a[] = "Kitty";
$a[] = "Linda";
$a[] = "Nina";
$a[] = "Ophelia";
$a[] = "Petunia";
$a[] = "Amanda";
$a[] = "Raquel";
$a[] = "Cindy";
$a[] = "Doris";
$a[] = "Eve";
$a[] = "Evita";
$a[] = "Sunniva";
$a[] = "Tove";
$a[] = "Unni";
$a[] = "Violet";
$a[] = "Liza";
$a[] = "Elizabeth";
$a[] = "Ellen";
$a[] = "Wenche";
$a[] = "Vicky";

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

$hint = "";

// lookup all hints from array if $q is different from ""
if ($q !== "") {
    $q = strtolower($q);
    $len=strlen($q);
    foreach($a as $name) {
        if (stristr($q, substr($name, 0, $len))) {
            if ($hint === "") {
                $hint = $name;
            } else {
                $hint .= ", $name";
            }
        }
    }
}

// Output "no suggestion" if no hint was found or output correct values
echo $hint === "" ? "no suggestion" : $hint;
?>