婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 關(guān)于二次封裝jquery ajax辦法示例詳解

關(guān)于二次封裝jquery ajax辦法示例詳解

熱門(mén)標(biāo)簽:中國(guó)地圖標(biāo)注不明確情況介紹表 電銷(xiāo)機(jī)器人 長(zhǎng)春 立陶宛地圖標(biāo)注 河間市地圖標(biāo)注app 上海企業(yè)外呼系統(tǒng)價(jià)錢(qián) 地圖標(biāo)注推銷(xiāo)坑人 大眾點(diǎn)評(píng)400電話怎么申請(qǐng) 東平縣地圖標(biāo)注app 怎樣在地圖標(biāo)注文字

前言

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

AJax所涉及到得技術(shù):

       1.使用CSS和XHTML來(lái)表示。

       2. 使用DOM模型來(lái)交互和動(dòng)態(tài)顯示。

       3.使用XMLHttpRequest來(lái)和服務(wù)器進(jìn)行異步通信。(核心)

       4.使用javascript來(lái)綁定和調(diào)用。

在我們前端處理數(shù)據(jù)的時(shí)候免不了要 ajax 與后臺(tái)通信, ajax 是通過(guò) XMLHttpRequest 對(duì)象與服務(wù)器進(jìn)行通信的, jquery 在 XMLHttpReaquest 的基礎(chǔ)上封裝了 $.ajax 辦法進(jìn)行通信, $.ajax 辦法實(shí)用性非常強(qiáng),又非常簡(jiǎn)單易用。 本次二次封裝 query ajax,參考 express 可以添加中間件處理數(shù)據(jù),返回 Promise(Defferd) 對(duì)象,減少回調(diào), 寫(xiě) ajax 更加簡(jiǎn)潔、優(yōu)雅。

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

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

痛點(diǎn)

但是在項(xiàng)目中使用 $.ajax, 它還是有一些痛點(diǎn)的

就是現(xiàn)在基本所有項(xiàng)目的 ajax 返回的數(shù)據(jù)也是進(jìn)行了二次封裝,加入了后臺(tái)在處理業(yè)務(wù)邏輯時(shí)的信息。

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

如果每一個(gè) ajax 請(qǐng)求回來(lái)都要判斷 code 是否正確再進(jìn)行業(yè)務(wù)邏輯處理或者報(bào)錯(cuò)提醒, 整個(gè)項(xiàng)目下來(lái)也太冗余了,

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

為了解決這個(gè)問(wèn)題,我們用一個(gè)函數(shù)再次封裝 $.ajax, 把這種正確與否判斷再處理業(yè)務(wù)邏輯或者報(bào)錯(cuò)提醒提取出來(lái)做成公共的部分。

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 使用就可以減少了業(yè)務(wù)錯(cuò)誤的判斷啦。 我們?cè)賮?lái)完善下, 不使用回調(diào)的方式,使用 promise 的方式調(diào)用, 減少回調(diào),讓代碼更清晰。

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('接口出錯(cuò),請(qǐng)重試');
 })
 return deferred.fail(function (err) {
  alert(err)
 });
}


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

中間件

這是一個(gè)公共的辦法,但是有時(shí)候我們需要處理差異化啊, 我們參考 express 引入一個(gè)中間件來(lái)解決差異化問(wèn)題。

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('接口出錯(cuò),請(qǐng)重試');
 })

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

// 調(diào)用
// 調(diào)用
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)
 })

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • 基于jQuery的ajax方法封裝
  • 封裝了jQuery的Ajax請(qǐng)求全局配置
  • 對(duì)Jquery中的ajax再封裝,簡(jiǎn)化操作示例
  • jQuery Ajax 全局調(diào)用封裝實(shí)例代碼詳解
  • 淺析jQuery Ajax通用js封裝

標(biāo)簽:銅川 遼寧 內(nèi)江 玉樹(shù) 本溪 營(yíng)口 益陽(yáng) 四川

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《關(guān)于二次封裝jquery ajax辦法示例詳解》,本文關(guān)鍵詞  關(guān)于,二次,封裝,jquery,ajax,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《關(guān)于二次封裝jquery ajax辦法示例詳解》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于關(guān)于二次封裝jquery ajax辦法示例詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品综合久久| 久久久99精品免费观看不卡| 国产精品久久久久久久岛一牛影视 | 亚洲国产欧美日韩另类综合| 日欧美一区二区| 黄页网站大全一区二区| 亚洲超碰97人人做人人爱| 午夜成人在线视频| 国产精品一品视频| 在线播放国产精品二区一二区四区| 亚洲一二三四在线观看| 麻豆精品国产传媒mv男同| 国产乱子轮精品视频| 在线视频国内自拍亚洲视频| 久久九九99视频| 奇米影视一区二区三区| www.爱久久.com| 播五月开心婷婷综合| 欧美美女bb生活片| 国产精品电影一区二区三区| 久久久不卡影院| 亚洲成av人片在线观看| 成人精品gif动图一区| 欧美日韩高清不卡| 亚洲男人天堂av网| 国产·精品毛片| 成人黄色av电影| 欧美成人精品高清在线播放| 日韩欧美一卡二卡| 午夜视频在线观看一区| caoporn国产精品| 亚洲成人动漫av| 久久婷婷色综合| 美女一区二区三区| 日韩欧美电影在线| 国产视频亚洲色图| 91在线porny国产在线看| 久久久精品tv| 国产suv精品一区二区三区| 在线看日韩精品电影| 国产精品国产精品国产专区不片| 国产精品911| 久久久久88色偷偷免费| 欧美日韩一区不卡| 亚洲成人黄色小说| 欧美日韩国产小视频在线观看| 伊人性伊人情综合网| 色综合中文字幕| 国产精品进线69影院| 国产一区二区三区黄视频| 欧美激情综合五月色丁香| 精品国产乱码久久久久久蜜臀| 色婷婷精品大在线视频| 成人aaaa免费全部观看| 日产欧产美韩系列久久99| 亚洲国产精品一区二区www在线 | 色综合久久综合中文综合网| 国产乱理伦片在线观看夜一区| 亚洲国产精品欧美一二99| 中日韩av电影| 国产日韩欧美电影| 久久久三级国产网站| 久久噜噜亚洲综合| 国产精品视频你懂的| 久久久久久久久免费| 久久久久久综合| 久久久久久久久久久黄色| 久久久久久一二三区| 久久精品人人做人人爽人人| 欧美激情一区不卡| 国产精品视频在线看| 最好看的中文字幕久久| 亚洲欧洲综合另类| 五月婷婷综合网| 男人的天堂亚洲一区| 韩国欧美国产一区| 麻豆一区二区99久久久久| 九九视频精品免费| 国内精品自线一区二区三区视频| 国产乱色国产精品免费视频| 丁香婷婷深情五月亚洲| 在线观看精品一区| 日韩视频在线你懂得| 欧美激情综合五月色丁香| 日本一二三不卡| 亚洲免费av观看| 婷婷久久综合九色综合伊人色| 麻豆freexxxx性91精品| 国产 日韩 欧美大片| 91免费观看在线| 欧美一区二区三区在线视频| 日韩欧美国产一二三区| 国产欧美日韩在线观看| 亚洲精品中文在线观看| 精品一区中文字幕| 成人精品鲁一区一区二区| 欧美日韩一本到| 欧美mv日韩mv国产网站app| 久久久亚洲综合| 一区二区三区四区乱视频| 日本视频一区二区三区| 成人免费av网站| 日韩视频一区二区三区在线播放 | 日本电影欧美片| 日本国产一区二区| 欧美一区二区三区在线观看| 亚洲欧洲日本在线| 美国av一区二区| 一本色道a无线码一区v| 波波电影院一区二区三区| 91精品中文字幕一区二区三区| 中文字幕av免费专区久久| 国产毛片一区二区| 91精品国产高清一区二区三区蜜臀| 精品日产卡一卡二卡麻豆| 在线观看www91| 在线免费不卡电影| 9久草视频在线视频精品| av不卡在线观看| 99re亚洲国产精品| av不卡免费电影| 欧美午夜精品免费| 欧美福利视频导航| 日韩美女主播在线视频一区二区三区 | 欧美一区二区私人影院日本| 亚洲国产毛片aaaaa无费看| 日韩欧美在线综合网| 国产精品伊人色| 亚洲一区二区三区四区五区黄| 亚洲一区成人在线| www.日韩在线| 国产欧美在线观看一区| 亚洲永久免费av| 成人高清av在线| 久久久久久久综合色一本| 亚洲精品免费一二三区| 国产精品夜夜嗨| 国产无遮挡一区二区三区毛片日本| 亚洲第一综合色| 欧美日本在线看| 日韩高清一区二区| 欧美日韩国产高清一区二区三区| 一区二区三区影院| 色香蕉久久蜜桃| 亚洲精品成人悠悠色影视| 91亚洲永久精品| 一区二区三区在线观看动漫| 色综合久久久久网| 亚洲第一搞黄网站| 日韩女优av电影| 狠狠色丁香婷婷综合| 久久亚洲影视婷婷| 成人av影视在线观看| 亚洲精品国产精华液| 欧美日韩久久不卡| 国产精品福利av| 在线视频你懂得一区| 午夜久久久影院| 欧美大片在线观看一区二区| 国产一区不卡视频| 亚洲免费观看高清完整| 欧美一卡2卡三卡4卡5免费| 国产高清精品网站| 亚洲免费观看高清完整版在线观看熊 | 欧美本精品男人aⅴ天堂| 国产激情91久久精品导航| 国产精品美女久久福利网站| 欧美视频在线一区二区三区 | 久久久不卡影院| eeuss鲁片一区二区三区在线看| 亚洲国产综合91精品麻豆| 不卡的av在线| 亚洲v中文字幕| 国产日韩v精品一区二区| 欧美优质美女网站| 日韩中文欧美在线| 国产色综合一区| 欧美电影在哪看比较好| 成人黄色综合网站| 亚洲电影你懂得| 中文字幕在线一区二区三区| 欧美特级限制片免费在线观看| 国产精品一卡二| 日韩成人伦理电影在线观看| 中文字幕二三区不卡| 67194成人在线观看| 99久久精品国产精品久久| 久久99精品久久只有精品| 亚洲精品乱码久久久久| 亚洲精品一区二区三区福利 | 99免费精品视频| 精品一区二区三区香蕉蜜桃| 亚洲免费在线看| 国产精品久久久爽爽爽麻豆色哟哟| 日韩精品在线网站| 欧美精品自拍偷拍| 在线观看成人小视频| 91蜜桃免费观看视频| 成人久久视频在线观看| 麻豆国产精品视频|