代码改变世界

Vue的组件为什么要export default

2019-08-03 16:55  盛世游侠  阅读(2419)  评论(0编辑  收藏  举报

原文链接:https://www.cnblogs.com/blog-cxj2017522/p/8562536.html

 

归结起来就是以下几点:

 

1、Vue 是通过 webpack 实现的模块化,因此可以使用 import 来引入模块,这个import,export,exports default,require什么的模块化的方法,都不是vue的API,而是webpack的API,详见链接:https://webpack.docschina.org/api/module-methods 和 https://webpack.docschina.org/api/module-variables

 

2、因为是webpack的API,所以你还可以在 bulid/webpack.base.conf.js 文件中修改相关的模块化配置:

意思是,你的模块可以省略 ".js",".vue",“.json” 后缀,weebpack 会在之后自动添加上;可以用 "@" 符号代替 "src" 字符串等。

 

3.export 和export default 的区别在于:export 可以导出多个命名模块,export default 只能导出一个默认模块。但export default导出的模块可以匿名,引用的时候可以自定义模块名。

export 导出例子:

//demo1.js
export const str = 'hello world'

export function f(a){
    return a+1
}

//demo2.js 引入
import { str, f } from 'demo1'

 

export default导出例子:

//demo1.js
export default {
    a: 'hello',
    b: 'world'      
}

//demo2.js 引入
//引入的时候可以给这个模块取任意名字,例如 "obj",且不需要用大括号括起来。
import obj from 'demo1'

 

export 用来导出模块,Vue 的单文件组件通常需要导出一个对象,这个对象是 Vue 实例的选项对象,以便于在其它地方可以使用 import 引入。而 new Vue() 相当于一个构造函数,在入口文件 main.js 构造根组件的同时,如果根组件还包含其它子组件,那么 Vue 会通过引入的选项对象构造其对应的 Vue 实例,最终形成一棵组件树。