91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

二次封裝jquery ajax辦法的示例分析

發布時間:2021-07-26 14:13:40 來源:億速云 閱讀:196 作者:小新 欄目:web開發

這篇文章主要介紹二次封裝jquery ajax辦法的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

前言

Ajax 的全稱是Asynchronous JavaScript and XML 異步的javaScript和XML

AJax所涉及到得技術:

       1.使用CSS和XHTML來表示。

       2. 使用DOM模型來交互和動態顯示。

       3.使用XMLHttpRequest來和服務器進行異步通信。(核心)

       4.使用javascript來綁定和調用。

在我們前端處理數據的時候免不了要 ajax 與后臺通信, ajax 是通過 XMLHttpRequest 對象與服務器進行通信的, jquery 在 XMLHttpReaquest 的基礎上封裝了 $.ajax 辦法進行通信, $.ajax 辦法實用性非常強,又非常簡單易用。 本次二次封裝 query ajax,參考 express 可以添加中間件處理數據,返回 Promise(Defferd) 對象,減少回調, 寫 ajax 更加簡潔、優雅。

$.ajax({
 url: url,
 data: data,
 dataType: 'json',
 type: 'get',
 success: new Function(){},
 error: new Function(){},
 .......
})

大部分的時候我們只需要傳入 url 和 data, 就可以獲取到我們想到的數據了。

痛點

但是在項目中使用 $.ajax, 它還是有一些痛點的

就是現在基本所有項目的 ajax 返回的數據也是進行了二次封裝,加入了后臺在處理業務邏輯時的信息。

從返回 data, 變成 了 {code: 200, data:{}, err_msg:''}

如果每一個 ajax 請求回來都要判斷 code 是否正確再進行業務邏輯處理或者報錯提醒, 整個項目下來也太冗余了,

$.ajax({
 url: url,
 data: data,
 success: function(data){
 if(data.code == 200) {
  dosomething()
 } else {
 alert(data.err_msg);
 }
 }
})

為了解決這個問題,我們用一個函數再次封裝 $.ajax, 把這種正確與否判斷再處理業務邏輯或者報錯提醒提取出來做成公共的部分。

util.ajax = function(obj, successFn){
 $.ajax({
 url: obj.url || '/interface',
 data: obj.data || {},
 dataType: obj.dataType || 'json',
 type: obj.type || 'get',
 success: function(data){
  if (data.code != 200) {
  alert(data.err_msg);
  } else {
  successFn(data.data)
  }
 },
 error: function(err){
  alert(err)
 }
 })
}

promise

util.ajax 代替 $.ajax 使用就可以減少了業務錯誤的判斷啦。 我們再來完善下, 不使用回調的方式,使用 promise 的方式調用, 減少回調,讓代碼更清晰。

util.ajax = function(obj) {
 var deferred = $.Deferred();
 $.ajax({
  url: obj.url || '/interface',
  data: obj.data || {},
  dataType: obj.dataType || 'json',
  type: obj.type || 'get',
 }).success(function (data) {
  if (data.code != 200) {
   deferred.reject(data.err_msg);
  } else {
   deferred.resolve(data.data)
  }
 }).error(function (err) {
  deferred.reject('接口出錯,請重試');
 })
 return deferred.fail(function (err) {
  alert(err)
 });
}


// 調用
var obj = {
 url: '/interface',
 data: {
  interface_name: 'name',
  interface_params: JSON.stringify({})
 }
};
util.ajax(obj)
 .done(function(data){
  dosomething(data)
 })

中間件

這是一個公共的辦法,但是有時候我們需要處理差異化啊, 我們參考 express 引入一個中間件來解決差異化問題。

util.ajax = function(obj, middleware) {
 var deferred = $.Deferred();
 $.ajax({
  url: obj.url || '/interface',
  data: obj.data || {},
  dataType: obj.dataType || 'json',
  type: obj.type || 'get',
 }).success(function (data) {
  if (data.code != 200) {
   deferred.reject(data.err_msg);
  } else {
   deferred.resolve(data.data)
  }
 }).error(function (err) {
  deferred.reject('接口出錯,請重試');
 })

 // 添加中間件
 if(!middleware) {
  middleware = function(){};
 }
 return deferred.done(middleware).fail(function (err) {
  message({
   content: err,
   type: 'error',
   showLeftIcon: true,
   duration: 5000
  });
 });
}

// 調用
// 調用
var obj = {
 url: '/interface',
 data: {
  interface_name: 'name',
  interface_params: JSON.stringify({})
 }
};
var middleware = function(data) {
 data.forEach(function(item){
  item.fullName = item.firstName + item.lastName
 })
}
util.ajax(obj, middleware)
 .done(function(data){
  console.log(data.fullName)
 })

以上是“二次封裝jquery ajax辦法的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

卢龙县| 彩票| 都江堰市| 平南县| 泰宁县| 潜山县| 芦溪县| 江阴市| 溧水县| 大埔区| 宜良县| 石楼县| 景洪市| 新巴尔虎左旗| 广汉市| 横峰县| 白水县| 霍山县| 阆中市| 甘肃省| 庆元县| 卢氏县| 姚安县| 宣威市| 乐至县| 赫章县| 广东省| 云浮市| 海门市| 灯塔市| 泾源县| 平武县| 乌兰察布市| 青冈县| 丰原市| 商洛市| 鄂州市| 辽源市| 策勒县| 赣榆县| 益阳市|