国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Web前端-Ajax基礎技術(下)

趙連江 / 1077人閱讀

摘要:前端基礎技術下你要明白是什么,怎么使用,程序是將信息放入公共的服務器,讓所有網絡用戶可以通過瀏覽器進行訪問。獲取字符串形式的響應數據,獲取形式的響應數據。基礎回顧原理是借助標簽發送跨域請求的技巧。

Web前端-Ajax基礎技術(下)

你要明白ajax是什么,怎么使用?

ajaxweb程序是將信息放入公共的服務器,讓所有網絡用戶可以通過瀏覽器進行訪問。

瀏覽器發送請求,獲取服務器的數據:

地址欄輸入地址,表單提交,特定的hrefsrc屬性。

// 封裝
function ajax(method, url, params) {

var xhr = new XMLHttpRequest();
xhr.open(method, url);
 
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
params = params || null;
xhr.send(params);
xhr.onreadystatechange=function(){
 if(this.readyState != 4) return
 console.log(this.responseText);
} 

}

ajax("GET", "time.php", "key=value");

function ajax(method, url, params) {

var xhr = new XMLHttpRequest();
if(method === "GET"){
 url += "?" + params;
}
xhr.open(method, url);

var data = null;
if(method === "POST") {
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
data = params
}

xhr.send(data);
xhr.onreadystatechange=function(){
 if(this.readyState != 4) return
 console.log(this.responseText);
} 

}
// 傳對象
function ajax(method, url, params) {

var xhr = new XMLHttpRequest();
if(typeof params === "object"){
 var tempArr = [];
 for(var key in params){
  var value = params[key];
  tempArr.push(key + "=" + value);
 } 
 params = tempArr.join("&");
}

if(method === "GET"){
 url += "?" + params;
}
xhr.open(method, url);

var data = null;
if(method === "POST") {
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
data = params
}

xhr.send(data);
xhr.onreadystatechange=function(){
 if(this.readyState != 4) return
 console.log(this.responseText);
} 

}
function ajax(method, url, params, done) {
method = method.toUpperCase();
var xhr = new XMLHttpRequest();
if(typeof params === "object"){
 var tempArr = [];
 for(var key in params){
  var value = params[key];
  tempArr.push(key + "=" + value);
 } 
 params = tempArr.join("&");
} 

if(method === "GET"){
 url += "?" + params;
}
xhr.open(method, url, false);

var data = null;
if(method === "POST") {
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
data = params
}

xhr.onreadystatechange=function(){
 if(this.readyState != 4) return
 // console.log(this.responseText);
 done(this.responseText);
} 
 
xhr.send(data);
}

var ondone = function(res) {
 console.log(res);
}

回調:

jquery中的ajax

https://www.jquery123.com/category/ajax/
function ajax(method, url, params, done) {
// 統一轉換大寫
 method = method.toUpperCase();
// urlencoded
 var pairs = [];
 for(var key in params) {
  pairs.push(key+"="+params[key]);
 }
 var querystring = pairs.join("&");
 var xhr = window.XMLHttpRequest?new XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHTTP");

xhr.addEventListener("readystatechange",function(){
 
}
}



$.ajax({
 url: "time.php",
 type: "post",
 data: { id: 1, name: "張三" },
 success: function(res) {
  console.log(res);
 }
})
$.ajax({
 url: "json.php",
 type: "get",
 dataType: "json",
 success: function(res) {
  console.log(res)
 }
})

ajax回調事件:




 
 


 
 




 
 


 
 


.ajaxComplete()
當ajax請求完成后注冊一個回調函數
.ajaxError()
ajax請求出錯
.ajaxSend()
ajax請求發送之前綁定一個要執行的函數
.ajaxStart()
在ajax請求剛開始時執行一個處理函數
.ajaxStop()
在ajax請求完成時執行一個處理函數
.ajaxSuccess()
綁定一個函數當ajax請求成功完成時執行
jQuery.ajax()
執行一個異步的http(ajax)請求
jQuery.ajaxPerfilter()
在每個請求之前被發送和$.ajax()處理它們前處理
jQuery.ajaxSetup()
為以后要用到的ajax請求設置默認的值
jQuery.ajaxTransport()
創建一個對象
jQuery.get()
使用一個http get請求從服務器加載數據
jQuery.getJSON()
jQuery.getScript()
GET請求從服務器加載并執行一個 JavaScript 文件
jQuery.post() 請求從服務器加載數據

跨域:
同源,域名,協議,端口,完全相同,同源的相互通過ajax的方式進行請求。
不同源地址之間,不能相互發送ajax請求。

$.get("http://", function(res) {
 console.log(res);
})


 
 AJAX基礎回顧


 

$.get("http://...", function(res){
 console.log(res);
})



var link = document.createElement("link");
link.rel = "stylesheet";
link.href = "http//...";
document.body.appendChild(link);

var script = document.createElement("script");
script.src = "http://...";
document.body.appendChild(script);

jsonp原理:
json是借助script標簽發送跨域請求的技巧。
原理是在客戶端借助script標簽請求服務端的一個動態網頁,服務端的這個動態網頁返回一段帶有函數調用的javascript全局函數調用的腳本,將原本需要返回給客戶端的數據傳遞進去。

$.ajax({
 url: "http://...",
 dataType: "json",
 success: function(res) {
  console.log(res);
 }
})

結言

好了,歡迎在留言區留言,與大家分享你的經驗和心得。

感謝你學習今天的內容,如果你覺得這篇文章對你有幫助的話,也歡迎把它分享給更多的朋友,感謝。

作者簡介

達叔,理工男,簡書作者&全棧工程師,感性理性兼備的寫作者,個人獨立開發者,我相信你也可以!閱讀他的文章,會上癮!,幫你成為更好的自己。長按下方二維碼可關注,歡迎分享,置頂尤佳。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/1099.html

相關文章

  • 前端相關大雜燴

    摘要:希望幫助更多的前端愛好者學習。前端開發者指南作者科迪林黎,由前端大師傾情贊助。翻譯最佳實踐譯者張捷滬江前端開發工程師當你問起有關與時,老司機們首先就會告訴你其實是個沒有網絡請求功能的庫。 前端基礎面試題(JS部分) 前端基礎面試題(JS部分) 學習 React.js 比你想象的要簡單 原文地址:Learning React.js is easier than you think 原文作...

    fuyi501 評論0 收藏0
  • Web前端-Ajax基礎技術(上)

    摘要:前端基礎技術上是瀏覽器提供一套的用于向服務器發出請求,接受服務端返回的響應,通過調用,實現通過代碼控制請求與響應,實現網絡編程。事件的狀態信息,從到變化,為請求未初始化,為建立連接成功,為請求已接收,為請求處理中,為請求完成。。 Web前端-Ajax基礎技術(上) ajax是瀏覽器提供一套的api,用于向服務器發出請求,接受服務端返回的響應,通過javascript調用,實現通過代碼控制...

    booster 評論0 收藏0
  • 前端2018現在上車還還得及么

    摘要:面向對象三大特征繼承性多態性封裝性接口。第五階段封裝一個屬于自己的框架框架封裝基礎事件流冒泡捕獲事件對象事件框架選擇框架。核心模塊和對象全局對象,,,事件驅動,事件發射器加密解密,路徑操作,序列化和反序列化文件流操作服務端與客戶端。 第一階段: HTML+CSS:HTML進階、CSS進階、div+css布局、HTML+css整站開發、 JavaScript基礎:Js基礎教程、js內置對...

    stormgens 評論0 收藏0
  • 前端2018現在上車還還得及么

    摘要:面向對象三大特征繼承性多態性封裝性接口。第五階段封裝一個屬于自己的框架框架封裝基礎事件流冒泡捕獲事件對象事件框架選擇框架。核心模塊和對象全局對象,,,事件驅動,事件發射器加密解密,路徑操作,序列化和反序列化文件流操作服務端與客戶端。 第一階段: HTML+CSS:HTML進階、CSS進階、div+css布局、HTML+css整站開發、 JavaScript基礎:Js基礎教程、js內置對...

    mylxsw 評論0 收藏0

發表評論

0條評論

趙連江

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<