Vue 的一个问题,虽然没什么用但是想搞清楚原因

2018-09-15 11:43:08 +08:00
 shintendo

问题:

为什么 new Vue({data: {a: 123})不会报错,而 new Vue({data: new Date()})会报"data functions should return an object"呢?

注意不是问 data 为什么要 function,而是{a: 123}和 new Date()都是 Object,为什么后者会报错,本质区别在什么地方?

关于为什么要传这么奇怪的参数:

是这样的,我在用 ElementUI 里面的$message.error()方法的时候,不小心传了个 Error 对象进去(应该传 message 字符串或者 options 对象),然后就报出了上述错误。出于好奇,我研究了一下 Element 的源码,发现这个参数最终是被传给了 new Vue({data: xxx}), 也就是说是 new Vue({data: new Error()})这句话报了上面的错。

然后我又试了一下,new Vue({data: xxx})里面,xxx 用任何 js 内置对象(Date/Array/Boolean...)都报"data functions should return an object",而用自定义的对象就不会,又打开 vue 的源码,搜了一下这句话没搜到,到这里我就无能为力了。

这问题好像没什么意义,毕竟正常人不会用内置对象去做组件 data,但是没弄清楚浑身难受。

3614 次点击
所在节点    Vue.js
6 条回复
noe132
2018-09-15 12:17:20 +08:00


https://github.com/vuejs/vue/blob/52719ccab8fccffbdf497b96d3731dc86f04c1ce/src/core/instance/state.js#L121
https://github.com/vuejs/vue/blob/52719ccab8fccffbdf497b96d3731dc86f04c1ce/src/shared/util.js#L58

理论上 data 只要是个对象类型就不会报错。
但是实际工程中,如果传的不是普通对象类型,那么很有可能在传参的时候出现了错误,这样有助于检查代码中可能出现的错误。
shintendo
2018-09-15 12:31:18 +08:00
@noe132
明白了,感谢!
这句判断和它给的警告有点搭不上啊?
SilentDepth
2018-09-15 14:26:40 +08:00
应该警告 should return plain object?
shintendo
2018-09-15 14:37:21 +08:00
@SilentDepth
因为这里 data 不是 function,所以它提示 data function 返回值不对,我就有点懵
yangxiongguo
2018-09-15 14:49:42 +08:00
调试了一下:
var _toString = Object.prototype.toString;
_toString.call(new Date()) 的结果是 "[object Date]",而不是 "[object Object]"
SilentDepth
2018-09-15 15:13:58 +08:00
@shintendo #4 可能 Vue 默认使用者不会错误地使用 new Vue 里的 data ……

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/489572

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX