搞不清除 vue.extend 的用途和 extends 的区别
还有 Vue.extend(require('./message.vue'))这是什么意思呢,为何不适应 import 呢
1
ghostgril OP 之前一直就只是使用.vue 文件,没注意过这个 vue.extend 的用途?
|
2
yuanbeibei 2018-04-23 17:30:07 +08:00
new Vue 是一个实例
vue.extend 组件构造器 需要传入 component 进行注册 vue.component 直接注册组件内部已经自动构造了 |
3
SilentDepth 2018-04-23 21:03:30 +08:00 3
Vue 是怎么用的相信你是知道的。我们把 new Vue({}) 生成的东西称为「赤果果的实例」,就是 options 里啥都没有,单纯一个空对象。
那么,new Vue({ /* something */ }) 就可以叫「有内容的实例」,options 对象里有内容了。 Vue.extend({ /* something */ }) 返回一个「有内容的类」,假定赋值给一个 VueWithSomething,然后你就可以这么用:new VueWithSomething()。你猜它返回什么?「有内容的实例」,因为这个构造器本身带着「内容」,即使 new 的时候没有传 options 那它也是有内容的,天生骄傲。 require('./message.vue') 返回什么?在 loader 配置正确的情况下,*.vue 文件会被 vue-loader 转换成一个 options 对象(不难想象,是吧)。那么 Vue.extend(require('./message.vue')) 就变成了什么呢? Vue.extend({ /* options-from-message */ }),一个「有内容的类」,而这个「内容」来自 message.vue 。 import 跟 Vue.extend() 没关系,跟 require 有关系,但超出这个主题的讨论范围了。 extends 是啥? TypeScript 的 extends ?那相当于语言语法层面的 Vue.extend()。 |
4
sunzongzheng 2018-04-23 22:23:21 +08:00 via Android
可以在逻辑层 new 一个 vue 组件进行操作。用途比如各种 modal 组件。没有显式挂在#app 下,但是可以动态创建
|
5
xtrueman83 2019-08-03 22:13:46 +08:00
没一个说得明白的
|