Javascript類庫:vue.js中的vue-resource示例詳解
Vue與后臺Api進(jìn)行交互通常是利用vue-resource來實(shí)現(xiàn)的,本質(zhì)上vue-resource是通過http來完成AJAX請求相應(yīng)的。這篇文章主要介紹了Vue中的vue-resource示例詳解,需要的朋友可以...
Vue與后臺Api進(jìn)行交互通常是利用vue-resource來實(shí)現(xiàn)的,本質(zhì)上vue-resource是通過http來完成AJAX請求相應(yīng)的。這篇文章主要介紹了Vue中的vue-resource示例詳解,需要的朋友可以參考下
vue-resource特點(diǎn)
vue-resource插件具有以下特點(diǎn):
1. 體積小 vue-resource非常小巧,在壓縮以后只有大約12KB,服務(wù)端啟用gzip壓縮后只有4.5KB大小,這遠(yuǎn)比jQuery的體積要小得多。
2. 支持主流的瀏覽器 和Vue.js一樣,vue-resource除了不支持IE 9以下的瀏覽器,其他主流的瀏覽器都支持。
3. 支持Promise API和URI Templates Promise是ES6的特性,Promise的中文含義為“先知”,Promise對象用于異步計(jì)算。 URI Templates表示URI模板,有些類似于ASP.NET MVC的路由模板。
4. 支持?jǐn)r截器 攔截器是全局的,攔截器可以在請求發(fā)送前和發(fā)送請求后做一些處理。攔截器在一些場景下會非常有用,比如請求發(fā)送前在headers中設(shè)置Access_token,或者在請求失敗時(shí),提供共通的處理方式。
下面通過示例看下Vue中的vue-resource一起看看吧
- 版本:vue-resource v1.2.1
- 作用:
  Vue與后臺Api進(jìn)行交互通常是利用vue-resource來實(shí)現(xiàn)的,本質(zhì)上vue-resource是通過http來完成AJAX請求相應(yīng)的。
用法:
Vue實(shí)例對象注冊this.$http服務(wù),可以發(fā)送HTTP請求。解析請求所返回的結(jié)果。此外,Vue實(shí)例將會自定綁定到this所在的回調(diào)函數(shù)中。
- {
- // GET /someUrl
- this- .$http.get(- '/someUrl'- ).then(response => {
- // success callback
- }, response => {
- // error callback
- });
- }
快捷方法列表
- get(url, [config])
- head(url, [config])
- delete- (url, [config])
- jsonp(url, [config])
- post(url, [body], [config])
- put(url, [body], [config])
- patch(url, [body], [config])
配置信息命令
響應(yīng)
源碼
下面我將以get請求訪問json文件的方式來展示vue-resource的用法。
html中的源碼
- <!DOCTYPE html>
- <html lang=- "en"- >
- <head>
- <meta charset=- "UTF-8"- >
- <title>vue-router</title>
- </head>
- <body>
- <div id=- "app"- >
- <ul>
- <li v-- for- =- "item in list"- >{{item.name}}</li>
- </ul>
- <button @click=- "getData"- >get請求</button>
- </div>
- <script src=- "../../../js/vue/vue/1.0/vue.js"- ></script>
- <script src=- "../../../js/vue/vue-resource/1.2.1/vue-resource.js"- ></script>
- <script type=- "application/javascript"- >
- var- vm =- new- Vue({
- el:- '#app'
- ,data:{
- list:[]
- }
- ,methods:{
- getData(){
- var- url =- '../json/get.json'- ;
- this- .$http.get(url).then(- function- (res){
- var- body = res.body;
- if- (body.status){
- alert(- '請求出錯(cuò)!'- );
- }
- this- .list = body.message;
- });
- }
- }
- });
- </script>
- </body>
- </html>
json文件中的源碼
- {
- "status"- :0
- ,- "message"- :[
- {
- "id"- :1
- ,- "name"- :- "張三"
- }
- ,{
- "id"- :2
- ,- "name"- :- "李四"
- }
- ]
- }
結(jié)果

分析
上面的代碼實(shí)現(xiàn)的功能是在頁面中通過點(diǎn)擊button按鈕來觸發(fā)一個(gè)getData的click響應(yīng)事件,而該事件實(shí)現(xiàn)的功能是發(fā)送一個(gè)url請求(盡管說其請求的是本地的json文件數(shù)據(jù),不過其請求后臺的方法和該方法是一模一樣的,所以說其用于請求后臺的數(shù)據(jù)也是同樣的用法。),該請求返回url鏈接所響應(yīng)的數(shù)據(jù)。而該返回?cái)?shù)據(jù)將會在then()回調(diào)函數(shù)中進(jìn)行相應(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ù)有變動(dòng),因而Vue會自定的刷新li的v-for中的頁面信息,進(jìn)而完成頁面信息的更新操作。
總結(jié)
以上所述是小編給大家介紹的Vue中的vue-resource示例詳解,希望對大家有所幫助。
  - Vue.js請求JSON Server服務(wù)器數(shù)據(jù)的實(shí)現(xiàn)方法- 文章主要介紹了Vue.js請求JSON Server服務(wù)器數(shù)據(jù)的實(shí)現(xiàn)方法,需要的朋友可以參考下。由于這里是在之前《vue.js中的vue-resource示例詳解》的基礎(chǔ)上進(jìn)行稍加修改完成的,因而其... 
  - javascript類庫:element ui table 增加篩選的方法示例- 文章主要介紹了element ui table 增加篩選的方法示例,詳細(xì)的介紹了如何添加規(guī)則內(nèi)容,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下網(wǎng)上大部分都可以增加篩選功能,但沒有找... 
  - 關(guān)于vue.js如何根據(jù)網(wǎng)站路由判斷頁面主題色教程詳解- 文章主要給大家介紹了關(guān)于vue如何根據(jù)網(wǎng)站路由判斷頁面主題色的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,... 
  - PHP遭棄用!Wordpress.com開源并轉(zhuǎn)用Javascript- 據(jù)外媒消息稱,Wordpress母公司Automattic將完全重寫Wordpress.com網(wǎng)站代碼,并將此項(xiàng)計(jì)劃命名為“Calypso”,代碼開源并被托管于Github平臺。此外,最新的wordpress.com放... 



