Javascript類庫:vue.js中的vue-resource示例詳解

2018-11-27 10:52:57 來源:互聯(lián)網(wǎng)作者:張偵毅 人氣: 次閱讀 595 條評論

Vue與后臺Api進行交互通常是利用vue-resource來實現(xiàn)的,本質(zhì)上vue-resource是通過http來完成AJAX請求相應(yīng)的。這篇文章主要介紹了Vue中的vue-resource示例詳解,需要的朋友可以...

Vue與后臺Api進行交互通常是利用vue-resource來實現(xiàn)的,本質(zhì)上vue-resource是通過http來完成AJAX請求相應(yīng)的。這篇文章主要介紹了Vue中的vue-resource示例詳解,需要的朋友可以參考下

vue-resource特點

vue-resource插件具有以下特點:

1. 體積小 vue-resource非常小巧,在壓縮以后只有大約12KB,服務(wù)端啟用gzip壓縮后只有4.5KB大小,這遠比jQuery的體積要小得多。

2. 支持主流的瀏覽器 和Vue.js一樣,vue-resource除了不支持IE 9以下的瀏覽器,其他主流的瀏覽器都支持。

3. 支持Promise API和URI Templates Promise是ES6的特性,Promise的中文含義為“先知”,Promise對象用于異步計算。 URI Templates表示URI模板,有些類似于ASP.NET MVC的路由模板。

4. 支持攔截器 攔截器是全局的,攔截器可以在請求發(fā)送前和發(fā)送請求后做一些處理。攔截器在一些場景下會非常有用,比如請求發(fā)送前在headers中設(shè)置Access_token,或者在請求失敗時,提供共通的處理方式。

下面通過示例看下Vue中的vue-resource一起看看吧

  • 版本:vue-resource v1.2.1
  • 作用:

  Vue與后臺Api進行交互通常是利用vue-resource來實現(xiàn)的,本質(zhì)上vue-resource是通過http來完成AJAX請求相應(yīng)的。

用法:

  Vue實例對象注冊this.$http服務(wù),可以發(fā)送HTTP請求。解析請求所返回的結(jié)果。此外,Vue實例將會自定綁定到this所在的回調(diào)函數(shù)中。

  1. {
  2.  // GET /someUrl
  3.  this.$http.get('/someUrl').then(response => {
  4.   // success callback
  5.  }, response => {
  6.   // error callback
  7.  });
  8. }

快捷方法列表

  1. get(url, [config])
  2. head(url, [config])
  3. delete(url, [config])
  4. jsonp(url, [config])
  5. post(url, [body], [config])
  6. put(url, [body], [config])
  7. patch(url, [body], [config])

配置信息命令

響應(yīng)

源碼

下面我將以get請求訪問json文件的方式來展示vue-resource的用法。

html中的源碼

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4.   <meta charset="UTF-8">
  5.   <title>vue-router</title>
  6. </head>
  7. <body>
  8.   <div id="app">
  9.     <ul>
  10.       <li v-for="item in list">{{item.name}}</li>
  11.     </ul>
  12.     <button @click="getData">get請求</button>
  13.   </div>
  14. <script src="../../../js/vue/vue/1.0/vue.js"></script>
  15. <script src="../../../js/vue/vue-resource/1.2.1/vue-resource.js"></script>
  16. <script type="application/javascript">
  17.   var vm = new Vue({
  18.     el:'#app'
  19.     ,data:{
  20.       list:[]
  21.     }
  22.     ,methods:{
  23.       getData(){
  24.         var url = '../json/get.json';
  25.         this.$http.get(url).then(function(res){
  26.           var body = res.body;
  27.           if(body.status){
  28.             alert('請求出錯!');
  29.           }
  30.           this.list = body.message;
  31.         });
  32.       }
  33.     }
  34.   });
  35. </script>
  36. </body>
  37. </html>

json文件中的源碼

  1. {
  2.  "status":0
  3.  ,"message":[
  4.   {
  5.    "id":1
  6.    ,"name":"張三"
  7.   }
  8.   ,{
  9.    "id":2
  10.    ,"name":"李四"
  11.   }
  12.  ]
  13. }

結(jié)果

分析

上面的代碼實現(xiàn)的功能是在頁面中通過點擊button按鈕來觸發(fā)一個getData的click響應(yīng)事件,而該事件實現(xiàn)的功能是發(fā)送一個url請求(盡管說其請求的是本地的json文件數(shù)據(jù),不過其請求后臺的方法和該方法是一模一樣的,所以說其用于請求后臺的數(shù)據(jù)也是同樣的用法。),該請求返回url鏈接所響應(yīng)的數(shù)據(jù)。而該返回數(shù)據(jù)將會在then()回調(diào)函數(shù)中進行相應(yīng)的處理,比如說我們的json文件中就返回了status響應(yīng)狀態(tài)碼,其中0代表成功,否則失敗。而一旦響應(yīng)成功,則調(diào)用body.message,將相應(yīng)的數(shù)據(jù)主體綁定到data數(shù)據(jù)域中的list中,由于list中的數(shù)據(jù)有變動,因而Vue會自定的刷新li的v-for中的頁面信息,進而完成頁面信息的更新操作。

總結(jié)

以上所述是小編給大家介紹的Vue中的vue-resource示例詳解,希望對大家有所幫助。