解析vue data不可以使用箭头函数问题


Posted in Javascript onJuly 03, 2018

首先需要明确,a() {}和 b: () => {}是不同的

let obj = {
   a() {},
   // 相当于
   a:function() {},
   b: () => {}
}

1 VUE.js 源码解析

注意此处只设计核心代码

这段代码也是UMD实现原理,本文这里不是重点,有兴趣的可以自行探究。

(function (global, factory) {
   typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
   typeof define === 'function' && define.amd ? define(factory) :
   (global.Vue = factory());
  }(this, (function (){
   'use strict';
    console.log(this) //*undefined*
  })))

解析一:

对于javascript来说,非严格模式下函数都会有一个this指向,不清楚的这里有传送门this指向相关

说一下本文中涉及的this指向问题,如果不是严格模式,this应该指向window,但是由于vue作者使用的是严格模式,所以他指向了undefined

以下是vue中data的实现原理

(function (global, factory) {
   typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
   typeof define === 'function' && define.amd ? define(factory) :
   (global.Vue = factory());
  }(this, (function (){
   'use strict';
   function getData(data,vm) {
    return data.call(vm, vm)
   }
   function initData(params) {
    data = vm._data = typeof data === 'function'
    ? getData(data, vm)
    : data || {};
   }
   initData()  
  })))

也就是说每次新创建实例的时候都会去判断是否有data函数,如果有的话就会将其赋值给vm._data,心细的同学会发现对于Vmm实例来说是没有data,而是有vm._data

es5函数和es6箭头函数

var obj = {
   a: () => {
   'use strict';
    console.log(this,'a')
   },
   b() {
    console.log(this,'b')
   },
   c() {
    // window
    let e = () => {
     console.log(this,'e')
    }
    return e
   }
  }
  obj.a() // window
  obj.b() // obj
  obj.c()() // obj

对于普通函数(非严格模式下),this指向调用者,es6中的this指向声明时的上下文环境。

结合以上两点解析今天的问题

(function (global, factory) {
   typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
   typeof define === 'function' && define.amd ? define(factory) :
   (global.Vue = factory());
  }(this, (function (){
   'use strict';
   let vm = {}
   var data = () => {
    console.log(this);//undefined
    return {
     a: 1
    }    
   }
   function getData(data,vm) {
    return data.call(vm, vm)
   }
   function initData(params) {
    data = vm._data = typeof data === 'function'
    ? getData(data, vm)
    : data || {};
   }
   initData()
   console.log(vm);
  })))

以上代码说明你使用箭头函数给data: () => {} this指向undefined的时候,是会赋值给vm._data,但是他会相当于一个全局的,只要你不刷新页面他就会缓存你的data。

如果我们使用data() {}this指向Vm实例,所以他会随着实例更新。

总结

以上所述是小编给大家介绍的vue data不可以使用箭头函数问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jquery ui dialog ie8出现滚动条的解决方法
Dec 06 Javascript
Table冻结表头示例代码
Aug 20 Javascript
node.js WEB开发中图片验证码的实现方法
Jun 03 Javascript
分享一个常用的javascript静态类
Dec 31 Javascript
Javascript控制div属性动态变化实例分析
Oct 08 Javascript
讲解JavaScript的Backbone.js框架的MVC结构设计理念
Feb 14 Javascript
js css实现垂直方向自适应的三角提示菜单
Jun 26 Javascript
js简单获取表单中单选按钮值的方法
Aug 23 Javascript
element-ui 表格实现单元格可编辑的示例
Feb 26 Javascript
详解webpack引入第三方库的方式以及注意事项
Jan 15 Javascript
探索node之事件循环的实现
Oct 30 Javascript
微信小程序实现弹幕墙(祝福墙)
Nov 18 Javascript
详解Vue SPA项目优化小记
Jul 03 #Javascript
jQuery实现表单动态添加与删除数据操作示例
Jul 03 #jQuery
JS实现显示当前日期的实例代码
Jul 03 #Javascript
jQuery实现获取form表单内容及绑定数据到form表单操作分析
Jul 03 #jQuery
vue 设置路由的登录权限的方法
Jul 03 #Javascript
jQuery阻止事件冒泡实例分析
Jul 03 #jQuery
详解VUE中常用的几种import(模块、文件)引入方式
Jul 03 #Javascript
You might like
php遍历所有文件及文件夹的方法深入解析
2013/06/08 PHP
ThinkPHP2.x防范XSS跨站攻击的方法
2015/09/25 PHP
php视频拍照上传头像功能实现代码分享
2015/10/08 PHP
Thinkphp3.2.3整合phpqrcode生成带logo的二维码
2016/07/21 PHP
PHP tp5中使用原生sql查询代码实例
2020/10/28 PHP
DOM相关内容速查手册
2007/02/07 Javascript
js判断浏览器类型的方法
2013/08/07 Javascript
jquery ajax 局部刷新小案例
2014/02/08 Javascript
jQuery中[attribute]选择器用法实例
2014/12/31 Javascript
JavaScript在Android的WebView中parseInt函数转换不正确问题解决方法
2015/04/25 Javascript
温习Javascript基础语法之词法结构
2016/05/31 Javascript
javascript实现随机生成DIV背景色
2016/06/20 Javascript
微信小程序 实例应用(记账)详解
2016/09/28 Javascript
AngularJS 中使用Swiper制作滚动图不能滑动的解决方法
2016/11/15 Javascript
JavaScript中关于for循环删除数组元素内容时出现的问题
2016/11/21 Javascript
JavaScript变量作用域_动力节点Java学院整理
2017/06/27 Javascript
浅谈js中的this问题
2017/08/31 Javascript
ES6中Array.copyWithin()函数的用法实例详解
2017/09/16 Javascript
element vue validate验证名称重复 输入框与后台重复验证 特殊字符 字符长度 及注意事项小结【实例代码】
2018/11/20 Javascript
在vue中使用setInterval的方法示例
2019/04/16 Javascript
vue+element使用动态加载路由方式实现三级菜单页面显示的操作
2020/08/04 Javascript
[01:30]我们共输赢 完美世界城市挑战赛开启全新赛季
2019/04/19 DOTA
Python使用xlrd读取Excel格式文件的方法
2015/03/10 Python
使用Python操作MySQL的一些基本方法
2015/08/16 Python
浅析Python中的getattr(),setattr(),delattr(),hasattr()
2016/06/14 Python
python opencv人脸检测提取及保存方法
2018/08/03 Python
Python3.5基础之变量、数据结构、条件和循环语句、break与continue语句实例详解
2019/04/26 Python
python几种常用功能实现代码实例
2019/12/25 Python
Python爬虫库BeautifulSoup获取对象(标签)名,属性,内容,注释
2020/01/25 Python
美国著名的团购网站:Woot
2016/08/02 全球购物
Sneaker Studio罗马尼亚网站:购买运动鞋
2018/11/04 全球购物
酒店管理毕业生自我鉴定
2014/03/02 职场文书
平安建设实施方案
2014/03/19 职场文书
党委班子对照检查材料
2014/08/19 职场文书
电力安全教育培训心得体会
2016/01/11 职场文书
Go gRPC进阶教程gRPC转换HTTP
2022/06/16 Golang