export,export default和import的区别以及用法

首先要知道export,import ,export default是什么html

ES6模块主要有两个功能:export和import函数

export用于对外输出本模块(一个文件能够理解为一个模块)变量的接口spa

import用于在一个模块中加载另外一个含有export接口的模块。htm

也就是说使用export命令定义了模块的对外接口之后,其余JS文件就能够经过import命令加载这个模块(文件)。这几个都是ES6的语法。blog

 

export和import(一个导出一个导入)接口

一个a.js文件有以下代码:io

 

export var name="李四";console

在其它文件里引用以下:function

import { name } from "/.a.js" //路径根据你的实际状况填写import

export default {

  data () {

    return { }

  },

  created:function(){

    alert(name)//能够弹出来“李四”

  }

 }

上面的例子是导出单个变量的写法,若是是导出多个变量就应该按照下边的方法,用大括号包裹着须要导出的变量:

 var name1="李四";

 var name2="张三";

 export { name1 ,name2 }

 

在其余文件里引用以下:

import { name1 , name2 } from "/.a.js" //路径根据你的实际状况填写

export default {

  data () {

    return { }

  },

  created:function(){

    alert(name1)//能够弹出来“李四”

    alert(name2)//能够弹出来“张三”

  }

 }

 

若是导出的是个函数呢,那应该怎么用呢,其实同样,以下

function add(x,y){

   alert(x*y)

  //  想想若是这里是个返回值好比: return x-y,下边的函数怎么引用

}

export { add }

在其余文件里引用以下:

import { add } from "/.a.js" //路径根据你的实际状况填写

export default {

  data () {

    return { }

  },

  created:function(){

   add(4,6) //弹出来24

  }

 }

 

export与export default

看完上面这几个例子,想必你必定了解了如何使用export,import,若是仍是不懂能够本身动手试一试。上面讲的是export和import,可是export跟export default 有什么区别呢?以下:

 

一、export与export default都可用于导出常量、函数、文件、模块等

二、你能够在其它文件或模块中经过import+(常量 | 函数 | 文件 | 模块)名的方式,将其导入,以便可以对其进行使用

三、在一个文件或模块中,export、import能够有多个,export default仅有一个

四、经过export方式导出,在导入时要加{ },export default则不须要

 

这样来讲其实不少时候export与export default能够实现一样的目的,只是用法有些区别。注意第四条,经过export方式导出,在导入时要加{ },export default则不须要。使用export default命令,为模块指定默认输出,这样就不须要知道所要加载模块的变量名。

var name="李四";

export { name }

//import { name } from "/.a.js"

能够写成:

var name="李四";

export default name

//import name from "/.a.js" 这里name不须要大括号

 

再看第3条,在一个文件或模块中,export、import能够有多个,export default仅有一个,也就是说以下代码:

var name1="李四";

var name2="张三";

export { name1 ,name2 }

 

也能够写成以下,也是能够的,import跟他相似。

 var name1="李四";

 var name2="张三";

 export name1;

 export name2;

 

使用export default命令,为模块指定默认输出,这样就不须要知道所要加载模块的变量名

//a.js

let sex = "boy";

export default sex(sex不能加大括号)

//本来直接export sex外部是没法识别的,加上default就能够了.可是一个文件内最多只能有一个export default。

其实此处至关于为sex变量值"boy"起了一个系统默认的变量名default,天然default只能有一个值,因此一个文件内不能有多个export default

 

// b.js

本质上,a.js文件的export default输出一个叫作default的变量,而后系统容许你为它取任意名字。因此能够为import的模块起任何变量名,且不须要用大括号包含

import any from "./a.js"

import any12 from "./a.js"

console.log(any,any12)   // boy,boy

 

原文出处:https://www.cnblogs.com/ranyonsue/p/10691335.html

相关文章
相关标签/搜索