精品熟女碰碰人人a久久,多姿,欧美欧美a v日韩中文字幕,日本福利片秋霞国产午夜,欧美成人禁片在线观看

Ajax常用封裝庫——Axios的使用
目錄

axios 是目前應用最為廣泛的 ajax 封裝庫

axios的特性有:

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

使用axios時,需要通過使用script標簽引入:https://unpkg.com/axios/dist/axios.min.js
axios的中文網鏈接:axios中文網

axios api

向axios()傳遞相關配置來創(chuàng)建請求;

  • axios(對象格式的配置選項)
  • axios(url,config)

常用的配置項

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

代碼展示如下:

<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<script>
 //使用axios方法    post請求
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 全局默認值的配置

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

axios攔截器:在請求或響應被then或catch處理前攔截它們

axios 的請求攔截器

//axios 的請求攔截器
axios.interceptors.request.use(function(config){
 //配置項config
  config.params = {
        id:2 //對配置項中的params進行更改,篩選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);
})
//多個axios方法也可以攔截

axios 的響應攔截器

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

axios的快速請求方法

 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請求,添加數(shù)據
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對xmlhttprequest類型全面升級,使其變得更加易用、強大。

onload / onprogress

  xml.onload 事件:只在請求完成時觸發(fā)

  xml.onprogress 事件:只在請求進行中觸發(fā)

//xhr.onload事件:只在請求完成時觸發(fā)
//xhr.onprogress事件:只在請求進行中觸發(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);
    //在周期性請求過程中,接收到的數(shù)據個數(shù)
     console.log(e.loaded);
     //接收數(shù)據的總個數(shù)
     console.log(e.total);
}
xhr.send(null);

response屬性

  以對象的形式表述響應體,其類型取決于responsetype的值。根據responsetype的值,來通過特定的類型請求數(shù)據。

  responsetype要在調用open()初始化請求之后,在調用send()發(fā)送請求到服務器之前設置才會有效。

//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常用封裝庫——axios的使用的詳細內容,更多關于ajax封裝庫axios的使用的資料請關注碩編程其它相關文章!

相關文章