如何解决vue中methods中的方法闭包缓存的问题
vue中methods中的方法闭包缓存问题
问题背景
需求描述
在路由的导航栏中需要, 判断是否为第一次点击
需要一个标志位来记录是否点击过
现状:
这个标志位只在一个函数中用过.不希望存放全局
希望在这个methods中形成闭包, 用来缓存这个函数
做出如下尝试后, 发现可以实现.
当前问题:
不能在闭包调用时找到正确的this.
诡异点
测试使用时: 返回的this找到了window
// 测试使用: <p id="app"> <button @click="test">测试按钮</button> </p> <script> var app = new Vue({ el: '#app', methods: { test: (() => { `use strict` console.log(this) // Window var flag = true return () => { console.log(this) // Window flag = false } })() } }) </script>
实际项目中的this变成了
undefined
更加诡异的是
debugger
之后, 我们一步步来看当前代码:
pointJump: (() => { let isFirstChanged = false; console.log(this); debugger; return entry => { console.log(this); console.log(isFirstChanged); debugger; isFirstChanged = true; }; })(),
操作:
刷新页面, 第一次函数立即执行
页面生成完成后: 我们再次通过按钮触发事件: 此时debugger显示内存中为Vue的*对象, 而在控制台打印出来的依旧是undefined
执行过程分析
第一次执行的时候为undefined是正常的, 因为第一次闭包执行, 没有找到this
当我们再次执行的时候, 虽然调用起来的上下文, 也就是this已经改了, 但是因为在作用域中那个
this
所代表的空间还是undefined
, 所以没有能改变过来.就造成了我们所看到的诡异的现象.
与测试文件有差别的原因
因为在测试环境下, 没有能开启严格模式.
经过两次不同位置的的开启尝试, 都不对
依旧可以找到window对象
现在推测是在vue内部进行的实现, 因为引入的vue版本不同.需要再进行测试, 看来源码还是要好好过一遍
<script> var app = new Vue({ el: '#app', methods: { test: (() => { `use strict` console.log(this) // Window var flag = true return () => { console.log(this) // Window flag = false } })() } }) </script>
最后找到原因的测试
因为箭头函数的this是不会改变, 拥有根据父级能够返回的this
然后因为上面的闭包环境中的this, 指向的一直都是
undefined
const test = (() => { let aaa = true; return function () { console.log(this); aaa = false; }; })(); mainJump(entry) { test.call(this); },
解决方法
形成闭包返回的函数中, 不要使用箭头函数, 使用function定义即可
pointJump: (() => { let isFirstChanged = false; return function () { console.log(this); // Vue的*对象 isFirstChanged = true; }; })(),
总结
箭头函数不会被call, bind等方法改变this指向
在闭包中返回函数, 缓存变量时, 使用function进行返回函数的定义.
以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!
相关推荐:
以上就是如何解决vue中methods中的方法闭包缓存的问题的详细内容,更多请关注其它相关文章!
上一篇: 用php代码写出❤️并自己定义文字
下一篇: Android 完美判断软键盘高度的方法
推荐阅读
-
jQuery中ajax的使用与缓存问题的解决方法
-
详解闭包解决jQuery中AJAX的外部变量问题
-
解决vue2.x中数据渲染以及vuex缓存的问题
-
如何解决婚姻中的问题?教你三种非常好用的方法
-
vue spa应用中的路由缓存问题与解决方案
-
IDEA,maven运行时缺少junit啊,servlet啊各种包,但是自己设置的仓库中明明有啊,这种问题如何解决
-
SpringCache @Cacheable 在同一个类中调用方法,导致缓存不生效的问题及解决办法
-
vue中axios解决跨域问题和拦截器的使用方法
-
Vue中消息横向滚动时setInterval清不掉的问题及解决方法
-
Vue.js 中取得后台原生HTML字符串 原样显示问题的解决方法