欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

通過實(shí)例解析jQ Ajax操作相關(guān)原理

 更新時(shí)間:2020年09月23日 08:38:40   作者:返回主頁WUWANLEI  
這篇文章主要介紹了通過實(shí)例解析jQ Ajax操作相關(guān)原理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

什么是AJAX

AJAX = 異步的javascript和XML(Asynchronous Javascript and XML)

它不是一門編程語言,而是利用JavaScript在保證頁面不被刷新、頁面鏈接不改變的情況下與服務(wù)器交換數(shù)據(jù)并更新部分網(wǎng)頁的技術(shù)。

對于傳統(tǒng)的網(wǎng)頁,如果想更新內(nèi)容,那么必須要刷新整個(gè)頁面,但有了Ajax,便可以在頁面不被全部刷新的情況下更新其內(nèi)容。在這個(gè)過程中,頁面實(shí)際上是在后臺(tái)與服務(wù)器進(jìn)行了數(shù)據(jù)交互,獲得數(shù)據(jù)之后,再利用JavaScript改變頁面,這樣頁面內(nèi)容就會(huì)更新了。(微博頁面加載過程的例子,加載一會(huì) 下方才會(huì)出現(xiàn)內(nèi)容,這其實(shí)就是Ajax加載的過程。)

簡言之,在不重載整個(gè)網(wǎng)頁的情況下,AJAX通過后臺(tái)加載數(shù)據(jù),并在網(wǎng)頁上進(jìn)行顯示。

通過 jQuery AJAX 方法,您能夠使用 HTTP Get 和 HTTP Post 從遠(yuǎn)程服務(wù)器上請求文本、HTML、XML 或 JSON - 同時(shí)您能夠把這些外部數(shù)據(jù)直接載入網(wǎng)頁的被選元素中。

1.jQuery的load()方法

jQuery load()方法是簡單但強(qiáng)大的AJAX方法。

load()方法從服務(wù)器加載數(shù)據(jù),并把返回的數(shù)據(jù)放入被選元素中。

語法:

$("selector").load(url,data,callback);
必須的url參數(shù)規(guī)定記載的url地址
可選的data參數(shù)規(guī)定與請求一同發(fā)送的查詢字符串鍵/值對的集合
可選的callback參數(shù)是load()方法完成后所執(zhí)行的函數(shù)名稱

1、
$('#btn').click(function(){

  //只傳一個(gè)url,表示在id為#new-projects的元素里加載index.html
  $('#new-projects').load('./index.html');
})
2、
$('#btn').click(function(){
  //只傳一個(gè)url,導(dǎo)入的index.html文件含有多個(gè)傳遞參數(shù),類似于:index/html?name='張三'
  $('#new-projects').load('./index.html',{"name":'張三',"age":12});
})
3、
  //加載文件之后,會(huì)有個(gè)回調(diào)函數(shù),表示加載成功的函數(shù)
  $('#new-projects').load('./index.html',{"name":'張三',"age":12},function(){

});
注意:load函數(shù)最好在服務(wù)器網(wǎng)頁中應(yīng)用,也就是說要在服務(wù)器上運(yùn)行,本地調(diào)試需要搭建后端本地環(huán)境。

2. jquery的getJSON方法

jQuery的AJAX中使用getJSON()方法異步加載JSON格式數(shù)據(jù)。獲取服務(wù)器中的數(shù)據(jù),并對數(shù)據(jù)進(jìn)行解析,顯示到頁面中

語法: $.getJSON(url,[data],[callback])

url參數(shù)為請求加載json格式文件的服務(wù)器地址,可選項(xiàng)data參數(shù)為請求時(shí)發(fā)送的數(shù)據(jù),callback參數(shù)為數(shù)據(jù)請求成功后執(zhí)行的函數(shù)
 $.getJSON("./data/getJSON.json", function (data) {
    var str = "";//初始化保存內(nèi)容變量
    $.each(data, function(index,ele) {
     $('ul').append("<li>"+ele.name+"</li>")

     });
    })

3.jquery的$.get()方法

$.get() 方法通過 HTTP GET 請求從服務(wù)器上請求數(shù)據(jù)

語法:$.get(URL,callback);

url參數(shù)規(guī)定你請求的路徑,是必需參數(shù),callback參數(shù)為數(shù)據(jù)請求成功后執(zhí)行的函數(shù)

        $.get('./data/getJSON.json',function(data,status){
  console.log(status);  //success  200狀態(tài)碼 ok的意思       
})

4.jquery的post()方法

與get()方法相比,post()方法多用于以POST方式向服務(wù)器發(fā)送數(shù)據(jù),服務(wù)器接收到數(shù)據(jù)之后,進(jìn)行處理,并將處理結(jié)果返回頁面#

語法:$.post(URL,data,callback);

url參數(shù)規(guī)定你請求的路徑,是必需參數(shù),可選的data參數(shù)是連同請求發(fā)送的數(shù)據(jù)??蛇x的callback參數(shù)為數(shù)據(jù)請求成功后執(zhí)行的函數(shù)
 $.post('/index',{name:'張三'},function(data,status){
   console.log(status);

 })

5. jquery的$.ajax()方法

是做ajax技術(shù)經(jīng)常使用的一個(gè)方法。 總結(jié)21幾個(gè)經(jīng)常使用的參數(shù)

參數(shù)如下:

1.url:

要求為String類型的參數(shù),(默認(rèn)為當(dāng)前頁地址)發(fā)送請求的地址。

2.type:

要求為String類型的參數(shù),請求方式(post或get)默認(rèn)為get。注意其他http請求方法,例如put和delete也可以使用,但僅部分瀏覽器支持。

3.timeout:

要求為Number類型的參數(shù),設(shè)置請求超時(shí)時(shí)間(毫秒)。此設(shè)置將覆蓋$.ajaxSetup()方法的全局設(shè)置。

4.async:

要求為Boolean類型的參數(shù),默認(rèn)設(shè)置為true,所有請求均為異步請求。如果需要發(fā)送同步請求,請將此選項(xiàng)設(shè)置為false。注意,同步請求將鎖住瀏覽器,用戶其他操作必須等待請求完成才可以執(zhí)行。

5.cache:

要求為Boolean類型的參數(shù),默認(rèn)為true(當(dāng)dataType為script時(shí),默認(rèn)為false),設(shè)置為false將不會(huì)從瀏覽器緩存中加載請求信息。

6.data:

要求為Object或String類型的參數(shù),發(fā)送到服務(wù)器的數(shù)據(jù)。如果已經(jīng)不是字符串,將自動(dòng)轉(zhuǎn)換為字符串格式。get請求中將附加在url后。防止這種自動(dòng)轉(zhuǎn)換,可以查看  processData選項(xiàng)。對象必須為key/value格式,例如{foo1:"bar1",foo2:"bar2"}轉(zhuǎn)換為&foo1=bar1&foo2=bar2。如果是數(shù)組,JQuery將自動(dòng)為不同值對應(yīng)同一個(gè)名稱。例如{foo:["bar1","bar2"]}轉(zhuǎn)換為&foo=bar1&foo=bar2。

7.dataType:

要求為String類型的參數(shù),預(yù)期服務(wù)器返回的數(shù)據(jù)類型。如果不指定,JQuery將自動(dòng)根據(jù)http包mime信息返回responseXML或responseText,并作為回調(diào)函數(shù)參數(shù)傳遞??捎玫念愋腿缦拢?xml:返回XML文檔,可用JQuery處理。 html:返回純文本HTML信息;包含的script標(biāo)簽會(huì)在插入DOM時(shí)執(zhí)行。 script:返回純文本JavaScript代碼。不會(huì)自動(dòng)緩存結(jié)果。除非設(shè)置了cache參數(shù)。注意在遠(yuǎn)程請求時(shí)(不在同一個(gè)域下),所有post請求都將轉(zhuǎn)為get請求。 json:返回JSON數(shù)據(jù)。 jsonp:JSONP格式。使用SONP形式調(diào)用函數(shù)時(shí),例如myurl?callback=?,JQuery將自動(dòng)替換后一個(gè)“?”為正確的函數(shù)名,以執(zhí)行回調(diào)函數(shù)。 text:返回純文本字符串。

8.beforeSend:

要求為Function類型的參數(shù),發(fā)送請求前可以修改XMLHttpRequest對象的函數(shù),例如添加自定義HTTP頭。在beforeSend中如果返回false可以取消本次ajax請求。XMLHttpRequest對象是惟一的參數(shù)。 function(XMLHttpRequest){ this; //調(diào)用本次ajax請求時(shí)傳遞的options參數(shù) }

9.complete:

要求為Function類型的參數(shù),請求完成后調(diào)用的回調(diào)函數(shù)(請求成功或失敗時(shí)均調(diào)用)。參數(shù):XMLHttpRequest對象和一個(gè)描述成功請求類型的字符串。 function(XMLHttpRequest, textStatus){ this; //調(diào)用本次ajax請求時(shí)傳遞的options參數(shù) }

10.success:

要求為Function類型的參數(shù),請求成功后調(diào)用的回調(diào)函數(shù),有兩個(gè)參數(shù)。 (1)由服務(wù)器返回,并根據(jù)dataType參數(shù)進(jìn)行處理后的數(shù)據(jù)。 (2)描述狀態(tài)的字符串。 function(data, textStatus){ //data可能是xmlDoc、jsonObj、html、text等等 this; //調(diào)用本次ajax請求時(shí)傳遞的options參數(shù) }

11.error:

要求為Function類型的參數(shù),請求失敗時(shí)被調(diào)用的函數(shù)。該函數(shù)有3個(gè)參數(shù),即XMLHttpRequest對象、錯(cuò)誤信息、捕獲的錯(cuò)誤對象(可選)。ajax事件函數(shù)如下: function(XMLHttpRequest, textStatus, errorThrown){ //通常情況下textStatus和errorThrown只有其中一個(gè)包含信息 this; //調(diào)用本次ajax請求時(shí)傳遞的options參數(shù) }

12.contentType:

要求為String類型的參數(shù),當(dāng)發(fā)送信息至服務(wù)器時(shí),內(nèi)容編碼類型默認(rèn)為"application/x-www-form-urlencoded"。該默認(rèn)值適合大多數(shù)應(yīng)用場合。

13.dataFilter:
要求為Function類型的參數(shù),給Ajax返回的原始數(shù)據(jù)進(jìn)行預(yù)處理的函數(shù)。提供data和type兩個(gè)參數(shù)。data是Ajax返回的原始數(shù)據(jù),type是調(diào)用jQuery.ajax時(shí)提供的dataType參數(shù)。函數(shù)返回的值將由jQuery進(jìn)一步處理。 function(data, type){ //返回處理后的數(shù)據(jù) return data; }

14.dataFilter:

要求為Function類型的參數(shù),給Ajax返回的原始數(shù)據(jù)進(jìn)行預(yù)處理的函數(shù)。提供data和type兩個(gè)參數(shù)。data是Ajax返回的原始數(shù)據(jù),type是調(diào)用jQuery.ajax時(shí)提供的dataType參數(shù)。函數(shù)返回的值將由jQuery進(jìn)一步處理。 function(data, type){ //返回處理后的數(shù)據(jù) return data; }

15.global:

要求為Boolean類型的參數(shù),默認(rèn)為true。表示是否觸發(fā)全局ajax事件。設(shè)置為false將不會(huì)觸發(fā)全局ajax事件,ajaxStart或ajaxStop可用于控制各種ajax事件。

16.ifModified:

要求為Boolean類型的參數(shù),默認(rèn)為false。僅在服務(wù)器數(shù)據(jù)改變時(shí)獲取新數(shù)據(jù)。服務(wù)器數(shù)據(jù)改變判斷的依據(jù)是Last-Modified頭信息。默認(rèn)值是false,即忽略頭信息。

17.jsonp:

要求為String類型的參數(shù),在一個(gè)jsonp請求中重寫回調(diào)函數(shù)的名字。該值用來替代在"callback=?"這種GET或POST請求中URL參數(shù)里的"callback"部分,例如{jsonp:'onJsonPLoad'}會(huì)導(dǎo)致將"onJsonPLoad=?"傳給服務(wù)器。

18.username:

要求為String類型的參數(shù),用于響應(yīng)HTTP訪問認(rèn)證請求的用戶名。

19.password:

要求為String類型的參數(shù),用于響應(yīng)HTTP訪問認(rèn)證請求的密碼。

20.processData:

要求為Boolean類型的參數(shù),默認(rèn)為true。默認(rèn)情況下,發(fā)送的數(shù)據(jù)將被轉(zhuǎn)換為對象(從技術(shù)角度來講并非字符串)以配合默認(rèn)內(nèi)容類型"application/x-www-form-urlencoded"。如果要發(fā)送DOM樹信息或者其他不希望轉(zhuǎn)換的信息,請?jiān)O(shè)置為false。

21.scriptCharset:

要求為String類型的參數(shù),只有當(dāng)請求時(shí)dataType為"jsonp"或者"script",并且type是GET時(shí)才會(huì)用于強(qiáng)制修改字符集(charset)。通常在本地和遠(yuǎn)程的內(nèi)容編碼不同時(shí)使用

//get()方式
 $.ajax({
   url:'./data/index.txt',
   type:'get',
   dataType:'text',
   success:function(data){
    $('p').html(data);

   },
   error:function(error){
    console.log(error)
   }
//post()方式
$.ajax({
  url:'/index',
  type:'post',
  data:{name:'張三',age:12},
  success:function(data){
   $('p').html(data);
  },
  error:function(error){
   console.log(error)
}

6.一個(gè)前后分離 產(chǎn)生交互的例子:

后臺(tái)server.py

# 通過flask框架搭建后臺(tái)
from flask import Flask, request
# 創(chuàng)建一個(gè)服務(wù)器對象
app = Flask(__name__)

# 解決ajax請求的跨域問題
from flask_cors import CORS
CORS(app, supports_credentials=True)

# 設(shè)置處理請求的功能(路由route => 接口)

# 設(shè)置一個(gè)主頁路由, 對應(yīng)一個(gè)處理主頁的功能方法, 返回主頁信息
@app.route('/')
def home_action():
  return '<h1 style="color: red">主頁</h1>'

# 為ajax登錄請求配置一個(gè)處理登錄的功能
@app.route('/login')
def login_action():
  # 拿到前臺(tái)數(shù)據(jù), 進(jìn)一步判斷處理
  # 需要: 需要賬號(hào)與密碼, 匹配成功與否決定返回結(jié)果
  user = request.args['user'] # 'user'是規(guī)定前臺(tái)需要傳入數(shù)據(jù)的key
  pwd = request.args['pwd']
  # print(user)
  if user == 'abc' and pwd == '123':
    return "登錄成功"
  return "登錄失敗"


# 啟動(dòng)服務(wù)(該文件作為自啟文件)
if __name__ == '__main__':
  app.run(port="8888")

前臺(tái).html

<h1>請登錄</h1>
<form class="fm">
  <input id="user" type="text" name="user" placeholder="請輸入用戶名">
  <input id="pwd" type="password" name="pwd" placeholder="請輸入密碼">

  <input class="sbm" type="submit" value="提交...">
</form>
// 取消表單的默認(rèn)事件
$('.fm').submit(function () { return false; })
// 表單提交完成的是ajax請求
$('.sbm').click(function () {
  // 前提: 準(zhǔn)備發(fā)送的數(shù)據(jù)
  var user = $('#user').val();
  var pwd = $('#pwd').val();

  // 1.通過ajax發(fā)生請求, 獲得后臺(tái)響應(yīng)的結(jié)果
  // 2.用得到的結(jié)果來局部渲染頁面內(nèi)容
  // 1.
  $.ajax({
    url: "http://127.0.0.1:8888/login", // 接口
    data: { // 數(shù)據(jù)
      user: user,
      pwd: pwd
    },
    success: function (data) { // 結(jié)果
      // 2.
      doSomething(data);
    }
  })
});
// 處理結(jié)果數(shù)據(jù)的功能
function doSomething(data) {
  // console.log(data)
  $('h1').text(data)
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論