用vue构建项目笔记6(在vue中使用vue resource)
来源:互联网 发布:评论系统源码 编辑:程序博客网 时间:2024/06/06 16:32
jquery用的是$.ajax。我们在vue项目中保持代码尽量精简而不引入jq的话,官方推荐vue resource.
使用vue resource有一个优势,就是this指向不会改变,即在调用完成之后直接写this就能调用到vue数据和方法,而如果写ajax,this指向变化,不得不在ajax之前先定义this指向另一个容器。
下面是一点使用vue resource的过程
1.安装 cnpm install vue-resource --save-dev
2、引入 找到main.js文件
import VueResource from 'vue-resource'Vue.use(VueResource);然后就可以在代码中愉快的调用了。
3、使用
this.$http.post(this.jsCtx+'aae',{id:id,state:state},{emulateJSON:true}).then(function(response){if(response.data.result==0){ }else{ alert(response.data.msg)}})这里有几个地方需要注意:
1、我用的是post请求的简略写法,如果是get请求,这样参数发送不了,下面是不简略的统一写法
this.$http({ url: this.jsCtx+'aa', method: 'get', // 请求体重发送的数据 params: { id:1 }, // 设置请求头 headers: { 'Content-Type': 'x-www-from-urlencoded' } }).then(function (response) { if(response.data.result==0){ }else{ } }, function () { // 请求失败回调 });get请求想要发送数据需要把数据写在params中,数据就会拼入链接后面发送了。post请求写在data中,其实也就是我第一种简略方法即可。
2.、第二个需要注意的是emulateJSON:true参数,官方描述大概就是默认是false,如果数据穿不过去就它写成true,其实就是关联到header的参数。
如果emulateJSON:true 则
如果emulateJSON:false(默认) 则
关于get请求怎么改header参数已经在上面的代码中体现了。
如果传JSON.stringify()的参数,是用emulateJSON:false的,除此之外,基本都要把emulateJSON改为true.
此外,官方还提供了可以统一设置控制请求接口前,请求后的操作,可以通过返回数据进行统一控制
Vue.http.interceptors.push(function ( request, next ) { // 请求发送前的处理逻辑//console.log(request)//console.log(next) next(function (response) { // 请求发送后的处理逻辑 // 更具请求的状态, response参数会返回给 successCallback或errorCallback//console.log(response.data.result)if(response.data.stats == undefined){this.$router.push('/')}// return response }); });
这个方法我是写在我上一篇文章的公用方法里的,可以让每个组件都调用到此方法具体如何创建公用方法js 移步
http://blog.csdn.net/qq_39507727/article/details/77482051点击打开链接
我在写这个方法的时候其实是想获取除200以外的状态值的,后台接口之前用的是jsp,当判断到用户尚未登录或者登录超时后,接口状态返回302,然后自动打开登录页面。然而我用这个接口的时候,根本找不到302这个状态值,返回的直接是打开登录页面的状态值200,所以无从判断是否登录超时,只能通过获取正确请求后必然返回的参数来判断接口是否请求成功。
- 用vue构建项目笔记6(在vue中使用vue resource)
- 用vue构建项目笔记5(在vue-cli项目中引用公用方法)(vue resource统一处理)
- 用vue构建项目笔记4(在vue中使用sass的配置)
- 用vue构建项目笔记7(在vue中引用公共过滤器filter)
- vue插件:vue-resource的使用笔记
- vue插件:vue-resource的使用笔记
- 构建vue全家桶项目-引入vue-resource
- 用vue-cli构建vue项目
- Vue系列——在vue项目中使用echarts
- Vue系列——在vue项目中使用echarts
- vue-cli构建vue项目
- vue-cli构建vue项目
- vue-cli构建vue项目
- vue-cli构建vue项目
- vue-cli构建vue项目
- vue-cli构建vue项目
- 在vue中使用vue-router指南
- 在vue项目中使用jquery
- 《Effective C++读书笔记》--条款02尽量以const,enum,inline替换#define
- JAVA 获取IP
- Zabbix搭建笔记[7]--触发器
- 【Struts2】(3)Struts2国际化、Struts2上传下载、Struts2标签使用
- IOS
- 用vue构建项目笔记6(在vue中使用vue resource)
- 为给俺的小白救星浏览器增加一个调试功能绞尽脑汁搞了2天了,终于搞出点眉目,不容易啊☺
- -0的存储在计算机中到底代表啥?
- 为什么需要项目管理软件
- springboot【23】监控管理之Actuator监控端点实践
- MongoDB学习笔记(入门)
- linux 下websocket server demo例程
- 洛谷1901 发射站
- spring boot启动过程