黄色电影一区二区,韩国少妇自慰A片免费看,精品人妻少妇一级毛片免费蜜桃AV按摩师 ,超碰 香蕉

Ajax常用封裝庫(kù)——Axios的使用
目錄

axios 是目前應(yīng)用最為廣泛的 ajax 封裝庫(kù)

axios的特性有:

  • 從瀏覽器中創(chuàng)建 xmlhttprequests
  • 從 node.js 創(chuàng)建 http 請(qǐng)求
  • 支持 promise api
  • 攔截請(qǐng)求和響應(yīng)
  • 轉(zhuǎn)換請(qǐng)求數(shù)據(jù)和響應(yīng)數(shù)據(jù)
  • 取消請(qǐng)求
  • 自動(dòng)轉(zhuǎn)換 json 數(shù)據(jù)
  • 客戶端支持防御 xsrf

使用axios時(shí),需要通過(guò)使用script標(biāo)簽引入:https://unpkg.com/axios/dist/axios.min.js
axios的中文網(wǎng)鏈接:axios中文網(wǎng)

axios api

向axios()傳遞相關(guān)配置來(lái)創(chuàng)建請(qǐng)求;

  • axios(對(duì)象格式的配置選項(xiàng))
  • axios(url,config)

常用的配置項(xiàng)

  • url:用于請(qǐng)求的服務(wù)器url
  • method:創(chuàng)建請(qǐng)求時(shí)使用的方法
  • baseurl:傳遞相對(duì)url前綴,將自動(dòng)加在url前面
  • headers:即將被發(fā)送的自定義請(qǐng)求頭
  • params:即將與請(qǐng)求一起發(fā)送的url參數(shù)
  • data:作為請(qǐng)求主體被發(fā)送的數(shù)據(jù)
  • timeout:指定請(qǐng)求超時(shí)的毫秒數(shù)(0表示無(wú)超時(shí)時(shí)間)
  • responsetype:表示服務(wù)器響應(yīng)的數(shù)據(jù)類(lèi)型,默認(rèn)“json”
axios().then(function(response){
 //正常請(qǐng)求的響應(yīng)信息對(duì)象response
})
.catch(function(error){
 //捕獲的錯(cuò)誤
})

代碼展示如下:

<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<script>
 //使用axios方法    post請(qǐng)求
axios({
         url:"/pinglun",
         method:"post",
         baseurl:"http://localhost:3000",
         header:{
               "content-type":"application/json"
         },
        data:{
            "content":"well",
            "lyid":4
         },
    timeout:1000,
  }).then(function(res){
       console.log(res.data);
   }).catch(function(error){
       console.log(error);
})
 </script>

axios 全局默認(rèn)值的配置

axios.defaults.baseurl = 'https://xxx.xxx.com';
axios.defaults.headers.post['content-type'] = 'application/x-www-form-urlencode'

axios攔截器:在請(qǐng)求或響應(yīng)被then或catch處理前攔截它們

axios 的請(qǐng)求攔截器

//axios 的請(qǐng)求攔截器
axios.interceptors.request.use(function(config){
 //配置項(xiàng)config
  config.params = {
        id:2 //對(duì)配置項(xiàng)中的params進(jìn)行更改,篩選id=2
    }
   return config;//要有返回值
})
    
//axios 方法
axios("http://localhost:3000/liuyan")
.then(function(res){
      console.log(res.data);
 })
.catch(function(error){
      console.log(error);
})
    
//axios 方法
axios("http://localhost:3000/pinglun")
.then(function (res) {
    console.log(res.data);
})
.catch(function (error) {
     console.log(error);
})
//多個(gè)axios方法也可以攔截

axios 的響應(yīng)攔截器

//axios 的響應(yīng)攔截器
axios.interceptors.response.use(function(response){
     return(response.data);//response里有很多值,選擇data即可
})
    
//axios 方法
axios("http://localhost:3000/liuyan")
.then(function (res) {
      console.log(res);//response那里攔截了,已經(jīng)將數(shù)據(jù)傳成data了
})
.catch(function (error) {
     console.log(error);
})

axios的快速請(qǐng)求方法

 axios.get(url[,config])

//axios.get(url[,config])
    
axios.get("http://localhost:3000/liuyan?id=2")
 .then(function(res){
     console.log(res.data);
})
    
axios.get("http://localhost:3000/liuyan",{
   params:{
        id:1
   }
}).then(function(res){
    console.log(res.data);
})

 axios.post(url[,data[,config]])

//axios.post(url[,data[,config]]) , post請(qǐng)求,添加數(shù)據(jù)
axios.post("http://localhost:3000/users",{
    name:"laowang",
    age:23,
    class:1
})

 axios.delete(url[,config])

//axios.delete(url[,config])
axios.delete("http://localhost:3000/liuyan",{
   params:{
         id:5
    }
})

 axios.put(url[,data[,config]])

//axios.put(url[,data[,config]])
axios.put("http://localhost:3000/liuyan",{
    name:"wangshisan",
    id:11
})

xmlhttprequest2.0,html5對(duì)xmlhttprequest類(lèi)型全面升級(jí),使其變得更加易用、強(qiáng)大。

onload / onprogress

  xml.onload 事件:只在請(qǐng)求完成時(shí)觸發(fā)

  xml.onprogress 事件:只在請(qǐng)求進(jìn)行中觸發(fā)

//xhr.onload事件:只在請(qǐng)求完成時(shí)觸發(fā)
//xhr.onprogress事件:只在請(qǐng)求進(jìn)行中觸發(fā)
var xhr = new xmlhttprequest();
xhr.open("get","http://localhost:3000/pinglun");
xhr.onload = function(){
     console.log("load:",this.readystate);
};
xhr.onprogress = function(e){
    console.log("progress:",this.readystate);
    //在周期性請(qǐng)求過(guò)程中,接收到的數(shù)據(jù)個(gè)數(shù)
     console.log(e.loaded);
     //接收數(shù)據(jù)的總個(gè)數(shù)
     console.log(e.total);
}
xhr.send(null);

response屬性

  以對(duì)象的形式表述響應(yīng)體,其類(lèi)型取決于responsetype的值。根據(jù)responsetype的值,來(lái)通過(guò)特定的類(lèi)型請(qǐng)求數(shù)據(jù)。

  responsetype要在調(diào)用open()初始化請(qǐng)求之后,在調(diào)用send()發(fā)送請(qǐng)求到服務(wù)器之前設(shè)置才會(huì)有效。

//xmlhttprequest之前的response返回
//responsetext
// responsexml
var xhr = new xmlhttprequest();
xhr.open("get","http://localhost:3000/pinglun");
xhr.onload = function(){
  var data = json.parse(this.responsetext);
          console.log(data);
   }
xhr.send(null);
           
// xhr2.0新增的response屬性 
// response
// responsetype
var xhr = new xmlhttprequest();
xhr.open("get","http://localhost:3000/liuyan");
xhr.responsetype = "json";
xhr.onload = function(){
    console.log(this.response);
}
xhr.send(null)

以上就是ajax常用封裝庫(kù)——axios的使用的詳細(xì)內(nèi)容,更多關(guān)于ajax封裝庫(kù)axios的使用的資料請(qǐng)關(guān)注碩編程其它相關(guān)文章!

相關(guān)文章