首頁 > web前端 > js教程 > ajax入門教程之30分鐘實例演示

ajax入門教程之30分鐘實例演示

云罗郡主
發布: 2019-01-25 13:16:13
原創
2789 人瀏覽過

在所有的教學中,不管是網路上的資料還是書籍上。都說,想要學會ajax,需要提前學會html css javascript就行了,然後很多前端初學者們就開始學,結果發現照著例子寫了半天愣是沒啥反應,最終果斷放棄~【推薦教程:AJAX影片教學

其實…你們沒有搭建後台環境啊,親~

1.先搭建一個後台環境吧?例如php

對於我們~前端的初學者來說,哪有這麼多精力時間去精學PHP啊,對吧?所以呢,推薦一個php環境搭建:phpstudy,只要下一步下一步的安裝就OK了。

我將PHPStudy安裝到了D盤,所以進入D盤找到phpstudy資料夾裡面的WWW資料夾

WWW資料夾就相當於我們電腦上的伺服器了,以後寫的所有東西,全部放到WWW資料夾。

在我們的WWW資料夾下面建立兩個文件,index.html和handle.php

#讓我們測試一下,在剛才新建的index.html中隨便寫點程式碼。打開瀏覽器,輸入localhost敲擊回車,如果能打開剛才寫的網頁,那麼就說明我們搭建成功

如果失敗,可能是端口衝突,也有可能是phpstudy木有運行~自己查一查調試一下

2.讓我們用PHP寫一個簡單的後台應用吧~

index.html
<body>
<form action="index.html" method="GET">
    <label for="name">姓名</label>
    <input type="text" id="name" name="name">
    <input type="submit" value="提交">
</form> 
</body>
登入後複製

不知道你們表單學的嘮樣,所以嘮叨兩句話:GET代表我們要使用的傳輸方式,對應的還有POST;

input標籤當中的id對應的是label標籤當中的for屬性;

input標籤當中的name屬性,一會要對接PHP使用;

handle.php

<meta charset="utf-8">
<!--其实我的这个写法有点取巧了,先凑合着看-->
<?php 
$student=array(
    array("name"=>"张三","sex"=>"男","age"=>"20"),
    array("name"=>"李丽","sex"=>"女","age"=>"19"),
    array("name"=>"王二","sex"=>"男","age"=>"21")
    );
$str="没有找到这个学生";
$name=$_GET["name"];
foreach ($student as $value) {
    if($value["name"]==$name){
        $str=$value["name"].",".$value["index"].",".$value["sex"].",".$value["age"];
        break;
    };
};
echo $str;
 ?>
登入後複製

3.換成Ajax的寫法!

index.html

html:

<h1>请输入姓名:</h1>
<input type="text" id="name">
<button onclick="submit()">提交</button>
<div id="text"></div>
登入後複製

javascript:

function submit(){
        
        var name=document.getElementById(&#39;name&#39;).value
               var text=document.getElementById(&#39;text&#39;)
        var XHR=new XMLHttpRequest();
               XHR.open("GET","handle.php?name="+name);
               XHRsend();
               XHR.onreadystatechange=function(){
            text.innerHTML=XHR.responseText
        }
登入後複製

注意:

如果有人把原始碼中的 text. innerHTML=XHR.responseText 改成了 alert(XHR.responseTXT),你將會發現,指令將會被執行多次。這時候,就要稍微的改一下程式碼了:(原因,在文章後面你會找到)

   ......
    XHR.onreadystatechange=function(){
             if(XHR.readyState==4){alert(XHR.responseText)};
                                     }
   ......
登入後複製

4.例子已經成功了,那我們就正式進入學習吧~

# ajax的優勢

在我們的第一個例子當中,是透過submit按鈕提交到php後台,然後再進行資料的處理操作。

這種操作呢,有一個弊端,就是需要把一整頁的資料同時提交到後台。

舉個栗子

如果我們在一個網站進行註冊,填寫完了暱稱,密碼,性別,年齡等信息,提交過去之後,後台告訴你暱稱已被使用,OK我們將暱稱,密碼,性別,年齡等,通通重寫,等再次提交過去,又告訴你暱稱依然已被使用。這時候你取了一個非常非常LOW的名字,心想,這回不會再出問題了吧?結果提交過去之後,後台告訴你,你的密碼過短需再次重新填寫資訊。恩~放棄了吧!

如果使用ajax技術呢?我們可以將資料逐條的提交到後台,也可以隨時隨地的提交。比如說,你填寫完暱稱,後台立刻告訴你暱稱被用,OK,改了就是嘍~。

AJAX的使用

1.建立AJAX

  var XHR=new XMLHttpRequest();
登入後複製

2.向伺服器發送請求

XHR.open("GET","handle.php",true);
XHR.send();
登入後複製

open裡面有三個參數,分別為資料傳輸方式,傳輸文件,是否非同步

當我們的傳輸方式為POST的時候,就會用上send(),如果是GET方式,推薦在send裡面寫上參數null

3 .GET vs POST

一句話:get更快,post更強

4.伺服器回應- 你把值傳過去了,咋也得傳回來點什麼吧?

ajax入門教程之30分鐘實例演示

XHR.responseText;
XHR.responseXML;
登入後複製

5.回應事件-什麼時候才能回傳資料嘞?

onreadystatechange 事件
两个属性:
readyState
status
登入後複製
每当 readyState 改变时,就会触发 onreadystatechange 事件。
readyState 属性存有 XMLHttpRequest 的状态信息。
登入後複製
XHR.onreadystatechange=function(){
                console.log(XHR.readyState)
                console.log(XHR.responseText)
登入後複製

ajax入門教程之30分鐘實例演示


#

以上是ajax入門教程之30分鐘實例演示的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:jianshu.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板