Vue export & export default & import 总结

by:授客 QQ1033553122

1.   实践环境

Vue 2.9.6

2.   简介

在ES6中,export与export default均可用于导出变量(含常量)、函数、类、文件、模块等,然后在其它文件或模块中通过import 变量(含常量)|函数|类|文件|模块名的方式,将其导入,以便能够对其进行使用。

 

3.   export & import

一个模块就是一个独立的文件,该文件内部的内容,外部无法获取。如果希望外部能够读取模块内部的内容,比如某个变量,就必须使用export关键字导出该变量,然后在其它模块中通过import方式导入使用。

假设module1.jsmodule2.js在同一个目录下。

导出\导入变量

// module1.js

export var author = "shouke"

export var addr = "sz"

// 等价写法

var author = "shouke"

var addr = "sz"

export { author, addr }

// module2.js

// 导入变量

import { author, addr } from "./module1"

// 也可以分开写

import { author } from "./module1"

import { addr } from "./module1"

// 引用变量

let temp = "addr of " + author + " is " + addr

console.log(author) // 输出 "shouke"

console.log(addr) // 输出 "sz"

console.log(temp) // "输出 addr of shouke is sz"

--------------------------------------------------------

// module1.js

var addr = "sz"

// 按别名导出

export { addr as address}

// module2.js

// 导入变量

import { address } from "./module1"

--------------------------------------------------------

// module1.js

var addr = "sz"

export { addr }

// module2.js

//使用as关键字给导入的变量重新取一个名字

import { addr as address } from "./module1"

console.log( myaddr)

注意:

1)   上面代码在export命令后面,使用大括号指定所要导出的一组变量、函数。它与前一种写法(直接放置在var语句前)是等价的,但是应该优先考虑使用这种写法。因为这样就可以在脚本尾部,一眼看清楚导出了哪些变量。

2)   import命令接受一对大括号,里面指定要从其他模块导入的变量名。大括号里面的变量名,必须与被导入模块(例中为module1.js)中导出的变量名称相同。

3)   import后面的from指定模块文件的位置,可以是相对路径,也可以是绝对路径,.js后缀可以省略。如果只是模块名,不带有路径,那么必须有配置文件,告诉 JavaScript 引擎该模块的位置。

常见的 import xxx from "@/someDir/someModule",这里 @ 默认代表 src目录,之所以这样,是因为在build/webpack.base.conf.js文件中做了对应配置,如下

resolve: {

extensions: ['.js', '.vue', '.json'],

alias: {

'vue$': 'vue/dist/vue.esm.js',

'@': resolve('src'),

}

},

4)   import命令具有提升效果,会提升到整个模块的头部,在编译阶段,在代码运行之前执行的

5)   如果多次重复执行同一句import语句,那么只会执行一次,而不会执行多次。

6)   import命令导入的变量都是只读的,不能对它进行修改。

import { addr } from "./module1"

addr = "other" // 报错 "addr" is read-only,import 命令导入的变量都是只读的,不能对它进行修改

当如,如果导入的是一个对象,则可以更改对象的属性

import {object} from './xxx.js'

object.atrr = 'hello'; // 合法操作

上面代码中,object的属性可以成功改写,并且其他模块也可以读到改写后的值。不过,这种写法很难查错,建议凡是输入的变量,都当作完全只读,轻易不要改变它的属性。

7)   export命令可以出现在模块的任何位置,只要处于模块顶层就可以

导出\导入函数

// module1.js

export function myfunc() {

console.log("run myfunc");

}

// 等价写法

function myfunc() {

console.log("run myfunc");

}

export { myfunc }

// module2.js

// 导入函数

import { myfunc } from "./module1"

// 调用函数

myfunc()

--------------------------------------------------------

// 按别名导出

// module1.js

function myfunc() {

console.log("run myfunc");

}

export { myfunc as func}

// module2.js

// 导入函数

import { func } from "./module1"

// 调用函数

func()

--------------------------------------------------------

// module1.js

export function myfunc() {

console.log("run myfunc")

}

// module2.j

//使用as关键字给导入的函数重新取一个名字

import { myfunc as func } from "./export"

func()

整体导入

import使用星号(*)指定一个对象,所有输出值都加载在这个对象上面。

// module1.js

function myfunc1() {

console.log("run myfunc1")

}

function myfunc2() {

console.log("run myfunc2")

}

export { myfunc1, myfunc2}

// module2.js

// 整体导入

import * as myfunc from "./module1"

// 函数调用

myfunc.myfunc1()

myfunc.myfunc2()

4.   export default && import

从前面的例子可以看出,使用import命令的时候,用户需要知道所要加载的变量名或函数名,否则无法加载。

为了给用户提供方便,让他们不用阅读文档就能加载模块,就要用到export default命令,为模块指定默认输出。

// module1.js

export default function () {

console.log("run myfunc")

}

// module2.js

// import customName from "./export"

// customName()

import func from "./export"

func()

// export defualt 也可以用于非匿名函数

// module1.js

export default function myfunc() {

console.log("run myfunc")

}

// 或者

function myfunc() {

console.log("run myfunc")

}

export default myfunc

-----------------------------------------

//export default和export同时使用

// module1.js

export function func() {

console.log("run func")

}

function myfunc() {

console.log("run myfunc")

}

export default myfunc

// module2.js

import myfunc, { func } from "./export"

func()

myfunc()

如上,模块文件module1.js的默认导出是一个匿名函数。其它模块使用import命令加载该模块时,可以为该匿名函数指定任意名称。

需要注意的是,导出模块使用了export default时,导入模块import命令后面,不使用大括号。

上面代码中,myfunc函数的函数名myfunc,在模块外部是无效的。加载的时候,视同匿名函数加载。

export default命令用于指定模块的默认输出。显然,一个模块只能有一个默认输出,因此export default命令只能使用一次。所以,import命令后面才不用加大括号,因为只可能唯一对应export default命令。

本质上,export default就是输出一个叫做default的变量或方法,然后系统允许你为它取任意名字。所以,下面的写法是有效的。

// modules.js

function add(x, y) {

return x * y;

}

export {add as default};

// 等同于

// export default add;

// app.js

import { default as foo } from 'modules';

// 等同于

// import foo from 'modules';

正是因为export default命令其实只是输出一个叫做default的变量,所以它后面不能跟变量声明语句。

// 正确

export var a = 1;

// 正确

var a = 1;

export default a;

// 错误

export default var a = 1;

上面代码中,export default a的含义是将变量a的值赋给变量default。所以,最后一种写法会报错。

同样地,因为export default命令的本质是将后面的值,赋给default变量,所以可以直接将一个值写在export default之后。

// 正确

export default 42;

// 报错

export 42;

上面代码中,最后一句报错是因为没有指定对外的接口,而前一句指定对外接口为default。

5.   import()

import()函数用于完成动态加载。

import(specifier)

参数specifier,指定所要加载的模块的位置。import命令能够接受什么参数,import()函数就能接受什么参数,两者区别主要是后者为动态加载。

import()函数可以用在任何地方,不仅仅是模块,非模块的脚本也可以使用。它是运行时执行,也就是说,什么时候运行到这一句,就会加载指定的模块。 import()类似于 Node 的require方法,区别主要是前者是异步加载,后者是同步加载。

6.   参考链接

http://es6.ruanyifeng.com/?search=import&x=0&y=0#docs/module#export-default-%E5%91%BD%E4%BB%A4

Vue export & export default & import 总结的更多相关文章

  1. 说明与比较:new Vue() 和 export default {}

    在生成.导出.导入.使用 Vue 组件的时候,像我这种新手就会常常被位于不同文件的 new Vue() 和 export default{}.它们含义到底是什么,又有什么异同呢? 首先,Vue 是什么 ...

  2. new Vue() 和 export default {}及Vue页面组件和标签组件说明与比较(非常重要)

    说明与比较:new Vue() 和 export default {} (1)vue就是一个构造函数 (2)vue标签组件:是HTML标签的扩展https://www.cnblogs.com/w-wa ...

  3. module.exports,exports,export和export default,import与require区别与联系【原创】

    还在为module.exports.exports.export和export default,import和require区别与联系发愁吗,这一篇基本就够了! 一.首先搞清楚一个基本问题: modu ...

  4. module.exports,exports,export和export default,import与require区别与联系

    还在为module.exports.exports.export和export default,import和require区别与联系发愁吗,这一篇基本就够了! 一.首先搞清楚一个基本问题: modu ...

  5. vue中export default 在console中是this.$vm

    vue中export default 在console中是this.$vm 用vue-cli搭出框架,用webstorm进行开发,参考vue2的官网进行教程学习, 在vue-cli中是用es6的exp ...

  6. module.exports exports 和export export default

    首先可以知道的是这是两组不同模块规范. module.exports 是CommonJS模块规范,通过require 导入 a.js: var x = 'hello' module.exports.x ...

  7. exports module.exports export export default之间的关系

    exports 和module.exports是CommonJS模块规范 export export default是ES6模块的规范,两者完全是不同的概念. node应用由模块组成,采用的是Comm ...

  8. 你可以说出export export default || model.exports exports 的区别吗(一)

    一.前言: 用模块写代码,为什么要用模块来写代码:ES6之前,在js中定义的一切,都是共享一个全局作用域的,随着web应用变得复杂,这样做会引起如:命名冲突和安全问题.于是引入了模块. 二.清楚一个概 ...

  9. C#可扩展编程之MEF学习笔记(二):MEF的导出(Export)和导入(Import)

    上一篇学习完了MEF的基础知识,编写了一个简单的DEMO,接下来接着上篇的内容继续学习,如果没有看过上一篇的内容, 请阅读:http://www.cnblogs.com/yunfeifei/p/392 ...

  10. ES6 & import * & import default & import JSON

    ES6 & import * & import default & import JSON import json & default value bug api.js ...

随机推荐

  1. aspnetcore插件开发dll热加载 二

    这一篇文章应该是个总结. 投简历的时候是不是有人问我有没有abp的开发经历,汗颜! 在各位大神的尝试及自己的总结下,还是实现了业务和主机服务分离,通过dll动态的加载卸载,控制器动态的删除添加. 项目 ...

  2. 使用SQL语句完成数据表的去重工作

    引入问题 可能大家都遇到过这样一种情况,一张表存在若干行数据,只是主键值相同,但是其它字段都是相同的,这就是我们通常所说的数据库重复数据,那我们是如何将这些数据删除呢?现在我们就介绍一种方法来实现数据 ...

  3. 在Mac上运行Rainbond,10分钟快速安装

    前言 以往安装部署 Rainbond 的方式都无法绕过 Kubernetes 集群的搭建,无论是作为开发环境还是用于生产交付,部署的过程都非常依赖于服务器或云主机.这在体验 Rainbond 云原生应 ...

  4. Cmockery学习

    什么是cmockery? 是一个轻量级的C语言单元测试框架 什么是单元测试? 单元测试就是测试一个系统的最小实现单元,往往是函数 示例解析 #include <stdarg.h> #inc ...

  5. Go的接口与多态

    什么是Go的接口? 接口可以说是一种类型,可以粗略的理解为他的变量是一堆方法. 一个简单的案例: r,_ := http.Get("http://www.baidu.com") i ...

  6. react组件传值(props[只读属性]) 函数组件

    组件间传值,在React中是通过只读属性 props 来完成数据传递的. props:接受任意的入参,并返回用于描述页面展示内容的 React 元素. function Cmp1(props) { r ...

  7. Vector + ClickHouse 收集日志

    目前业界的日志生态,最常用的是 ELK,其次就是 ClickHouse,本文会演示如何使用 Vector + ClickHouse 来采集 Nginx 日志并做清洗,最终写入 ClickHouse.至 ...

  8. LocalDateTime日期相互转换字符串

    /** LocalDateTime日期相互转换字符串 * 默认的时间日期样式 */ public static final String YYYYMMDDHHMMSSS_PATTERN = " ...

  9. Shell脚本实现Linux回收站

    前言 到目前为止,非图形化的Linux还没有回收站的命令. 那么,我们如果不小心将某一个文件删掉了,那就只能数据恢复了.如果这也不行,那就等着哭吧. 最新代码在我的github:https://git ...

  10. Java开发者的神经网络进阶指南:深入探讨交叉熵损失函数

    前言 今天来讲一下损失函数--交叉熵函数,什么是损失函数呢?大体就是真实与预测之间的差异,这个交叉熵(Cross Entropy)是Shannon信息论中一个重要概念,主要用于度量两个概率分布间的差异 ...