美文网首页
ES6-export default

ES6-export default

作者: 吴高亮 | 来源:发表于2019-01-21 20:48 被阅读0次

export default

export default 是默认将变量赋值给default;核心思想;
从上面的例子中;用户需要知道什么变量名称或者函数名称;才可以使用import进行引入;用户肯定希望快速上手;未必回去了解文档;去看文章了解那个文章那个属性;
在不阅读文档就能加载模块;使用export default命令;为模块指定默认输出;

//export-default.js
export default function(){
  console.log('foo');
};

上面代码是是一个模块文件;默认输出(export default)一个函数;
其他模块在加载该模块的时候;可以使用import对该匿名函数进行命名;

//import-default.js
import customName from './export-default';
customName();//foo;

上面代码的import命令,可以用任意名称指向export-default.js输出的方法,这时就不需要知道原模块输出的函数名。需要注意的是,这时import命令后面,不使用大括号。
export default用在其他命名函数前也是可以的;

// export-default.js
export default function foo() {
  console.log('foo');
}

// 或者写成

function foo() {
  console.log('foo');
}

export default foo;

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

下面比较一下默认输出和正常输出。

/ 第一组
export default function crc32() { // 输出
  // ...
}
import crc32 from 'crc32'; // 输入
// 第二组
export function crc32() { // 输出
  // ...
};
import {crc32} from 'crc32'; // 输入

上面代码的两组写法,第一组是使用export default时,对应的import语句不需要使用大括号;第二组是不使用export default时,对应的import语句需要使用大括号。

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 dafault 是将变量赋值给default所以可以直接将值写在后面;
export default 42 //正确;但是直接export 42就是错误;

export default也可以用来输出类。

// MyClass.js
export default class { ... }

// main.js
import MyClass from 'MyClass';
let o = new MyClass();

相关文章

  • ES6-export default

    export default export default 是默认将变量赋值给default;核心思想;从上面的例...

  • es6-export 和 export default

    总共有两种导出模块的方式:命名导出(export)和默认导出(export default) 命名导出 一个模块可...

  • RN export的那些事儿

    1 使用 export default 的区别 有default和没有default的区别在于:有default在...

  • DEFAULT

  • =default

    使用 =default 来获得默认的构造函数、拷贝控制函数、析构函数 特别的: 这样我们就可以不用显式的构造,而直...

  • default

    Java 8的接口上的default method最初的设计目的是让已经存在的接口可以演化——添加新方法而不需要原...

  • Android Activity launchMode

    "standard" (the default mode)Default. The system creates ...

  • spark 参数

    spark.default.parallelism Default number of partition...

  • java 8

    1.Default method The default method and static method of ...

  • es6 快速了解export与export default的用

    export 加default: 不加default 一个js文件中,只能有一个export default; 一...

网友评论

      本文标题:ES6-export default

      本文链接:https://www.haomeiwen.com/subject/pxehjqtx.html