vue 执行函数this_在vue中使用回调函数,this调用无效的解决

let self = this //使用新变量替换this,以免this无效

//updatestudentinfotoserver是一个将本身部分数据异步上传的接口,接收三个参数,其中第一个是数据,第二、三个是函数,第二、三个函数使用function(){}形式书写

updatestudentinfotoserver:function(data, networkok, networkerror){

let postdata = this.$qs.stringify({

data:data

})

this.axios.post('/api/update/updatestudentinfo',

postdata

).then(res=>{

console.log(' return : ')

console.log(res)

networkok(res) //网络成功的回调

}).catch(error=>{

console.log(error)

networkerror(error) //网络失败的回调

})

console.log('axios done')

},

this.updatestudentinfotoserver(data, function(res){

console.log('return ok')

console.log(res)

// console.log('self')

// console.log(self) //就是this

// console.log('this')

// console.log(this) //undefined

self.handlecanceledit()

},function(error){

console.log(error)

}

)

提交网络数据是异步调用,所以会先返回然后才执行成功、失败的回调。

这种书写方式,function的作用于决定了function的代码块内使用this无法改变、获取vue data中设置的变量

使用es6的箭头语法可以实现this的随处调用

this.updatestudentinfotoserver(this, res=>{

console.log('return ok')

console.log(res)

console.log('self')

console.log(self)

console.log('this')

console.log(this)//this和self一样

}, error=>{

console.log(error)

}

)

不过某些浏览器的某些版本不支持es6的语法,可能导致各种各样的问题

补充知识:vue在全局函数中加回调,调用vue文件中的函数

全局函数可以写一个文件globalfunc.js

exports.install = function(vue, option){

vue.prototype.setdata = function(that, key){

that[key] = '222'

}

vue.prototype.testcallme = function(str){

console.log('test call me' + str)

}

vue.prototype.testcallback = function(func, param){

func(param)

this.testcallme('tetetet')

}

}

main.js

vue.use(globalfunc)

vue文件中

调用

this.testcallback(this.test, 'yui0')//使用全局函数调用vue文件中的函数,修改vue文件中的数据

this.setdata(this, 'msg')//使用全局函数修改vue文件中的数据

test函数编写

test:function(str){

this.msg = '233' + str

},

以上这篇在vue中使用回调函数,this调用无效的解决就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持萬仟网。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/574215.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ECMall2.x模板制作入门系列之2(模板标签/语法)

ECMall2.x模板制作入门系列之2(模板标签/语法)今天给大家带来一个模板语法的教程。希望能为ECMall模板制作者提供一份参考资料。如有问题、建议和意见,欢迎提出。在ECMall模板中,用"{"开头,以"}"结…

win10运行vue项目_vue+webpack在window10环境下搭建及遇到的问题

首先我搭建vuewebpackvue-strapvue-routesass时,我用的是直接在项目中的package.json中的“devDependencies”直接将直接需要的一些插件写上。然后用“npm install”的方式。1、首先你要安装好nodejs。2、新建项目,在新建的项目vue中打开输入&#xff1a…

计算机教师专业发展规划,信息技术教师成长规划_信息技术教师专业成长浅谈...

科技日新月异,网络技术发展一日千里。信息技术教师责任重大,只有不断加强理论学习,在教学中勤于实践,才能跟上时代发展步伐。笔者结合自己的教学实践,谈几点认识与体会。  一、在理论学习中成长理论是指导我们教学行…

javascript设计模式-学习笔记

1.javascript模块模式 Module 模式最初被定义为传统软件工程为类解决私有和公有的方法. var M (function(){var q0;return {value:q} })()引入全局变量jquery var M (function($){var q$.trim(111);return {value:q} })(jQuery)引出 var M (function(){var q0;obj {value:q…

ipv6地址为什么显示两个_【聚焦】IPv6进行时,别被这些因素绊住脚

智慧宇易精挑细选2020年5933篇不能仅仅为了支持IPv6而使用IPv6,如何利用IPv6解决现实问题尤其重要。创新网络服务、应用服务、数据服务,可能是发展IPv6最重要的一个策略。11月15日,在第二届中国互联网基础资源大会上,IPv6被多位专…

HttpResponse 类

而封闭HTTP输出信息的类型就是HttpResponse类,使用HttpResponse类可以实现三种类型的输出,即文本,URL,二进制流. 实现这三类的属性和方法分别介绍如下:1.文本的输出,在日常开发中,后台中的文本可能需要输出到浏览器中,让用户浏览,这就需要实现动态HTML的输出,使用HttpResponse…

量子计算机迷宫,一个简单的例子,带你读懂量子计算机

原标题:一个简单的例子,带你读懂量子计算机量子计算机和你的笔记本电脑在本质上是一样的,使用的都是二进制编码。计算机语言只用0和1来表达,这被称为“位”,是计算机信息量最小的单位。计算机的工作,就是把…

各种门锁的内部结构图_便宜超好用:小米智能门锁 E上手体验报告

「真正的科技,是让你感受不到科技的存在」随着科技的日益飞速发展,科技改变着我们生活的方方面面,如今的我们出门必备的是手机,地铁、公交、日常消费、进出小区也逐渐使用手机或手环;2020年的当下钥匙已经变得不那么重要&#xff…

Unity3d通用工具类之定时触发器

时隔多日,好不容易挤出点时间来写写博文。不容易,请送我几朵红花,点个赞也行。 今天呢,我们主要来扩展下通用工具类>定时触发器。 顾名思义,所谓的定时触发器,就是告诉程序在过多长时间后,我…

北海计算机职称考试地点,【2017年广西北海职称计算机考试报名时间9月1日-5日】- 环球网校...

【摘要】环球网校提醒大家2017年广西北海职称计算机考试报名时间9月1日-5日以下介绍了北海职称计算机考试报名时间、准考证打印时间、考试时间等,希望对大家有帮助更多资料敬请关注环球职称计算机考试频道,【摘要】环球网校提醒大家“2017年广西北海职称…

disp语句怎么格式 matlab_Matlab使用技巧总结-1

抽空看了Matlab官方文档,并配合郭老师的课程,把Matlab语言系统梳理了一遍。先上资源:bilibili良心搬运大法:MATLAB_台大郭彦甫-视频教程知乎盐选推荐基础教程:MATLAB 2016_基础实例教程以下记录了一些matlab的技巧。【…

采用CXF+spring+restful创建一个web接口项目

这篇文章是http://blog.csdn.net/zxnlmj/article/details/28880303下面,加入的基础上的restful特征 1、参加restful必jar包裹 jsr311-api-1.0.jarCXF与JAX-RS版本号相应问题,參考自:http://bioubiou.iteye.com/blog/1866871 CXF支持REST风格的Web服务&am…

计算机结构介绍,计算机系统结构介绍.pdf

第三次作业5.7 一条线性流水线由4 个功能段组成,每个功能段的延迟时间都相等,都为 。开始5t个 ,每间隔一个 向流水线输入一个任务,然后停顿2 个 ,如此重复。求流水t t t线的实际吞吐率、加速比和效率。(10 分)…

古风一棵桃花树简笔画_为什么,很多农村家庭的院子里,会喜欢种一棵樱桃树呢?...

小伙伴们去农村的时候,应该都会注意到几乎每家每户的院子里都会种有几棵树吧。如果小伙伴们认真观察的话,你们可以发现很多农村家庭的院子里都有种一两棵樱桃树。那么这是为什么呢?是因为樱桃比较好吃吗?是有这个原因的&#xff0…

Python【02】【基础部分】- B

1、作用域 变量只要在内存存在,就可以被使用 。(栈) 1 if 1 1: 2 name kim 3 print name 个例:item的值为字典循环后最后一个key的值 1 name {xiaoming:12,xiaohua:15,xiaoli:11} 2 for item in name: 3 print item 4 …

计算机用语优秀怎么算,计算机专业用语

computer-hardware~计算机硬件motherboard~主板cpu(central~processor~unit)-中央处理器memory-存储器,内存条monitor~显示器mouse~鼠标keyboard~键盘peripheral-外部设备printer~打印机scanner~扫描仪speaker~音响RAM(Random access memory)随机存储器hard~disk 硬…

冯诺依曼机器人_冯·诺依曼型计算机的五大组成部分是什么?

在DSP算法中,最大量的工作之一是与存储器交换信息,这其中包括作为输入信号的采样数据、滤波器系数和程序指令。例如,如果将保存在存储器中的2个数相乘,就需要从存储器中取3个二进制数,即2个要乘的数和1个描述如何去做的…

(转)数字格式化函数:Highcharts.numberFormat()

一、函数说明 该函数用于图表中数值的格式化,常见用途有数值精度控制、小数点符、千位符显示控制等。二、函数使用1、函数构造及参数Highcharts.numberFormat (Number number, [Number decimals], [String decimalPoint], [String thousandsSep])参数列表number 需…

usb3.0 ssd 测试软件,SSD打造的移动硬盘,顺便测下USB2.0、USB3.0、SATA2.0、SATA3.0传输速度...

本帖最后由 神经病的春天 于 2014-9-18 15:36 编辑近来升级了一下主机,这样一来,终于能够拥有USB3.0和SATA3.0接口了,不过本人目前还木有SSD,所以尚无法完全发挥出这些接口的速度优势。 为了测试,上周的时候&#xff0…

cad图层管理插件_设计大神CAD常用七个插件你会用几个?

如果你需要这些CAD插件,可以私信我,小编会及时发给大家​​ 说道CAD插件可能会被人们熟知的也就那几个,可是据统计CAD插件多达上百个,那么在这上百个插件中你又会用几个呢?下面就让我们看看大部分设计师常用的插件有哪…