Skip to content

huanggithub/ES6

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 

Repository files navigation

Module-grammar-of-ES6

ES6中module的语法

严格模式

ES6模块下自动采用严格模式,不管有没有加入"use-strict".  
限制主要包括:  
    - 变量必须声明后再用
    - 函数的参数不能有同名属性,否则报错
    - 不能使用 with 语句
    - 不能对只读属性赋值,否则报错
    - 不能使用前缀 0 表示八进制数,否则报错
    - 不能删除不可删除的属性,否则报错
    - 不能删除变量 delete prop,会报错,只能删除属性 delete global[prop]
    - eval 不会在它的外层作用域引入变量
    - eval 和 arguments 不能被重新赋值
    - arguments 不会自动反映函数参数的变化
    - 不能使用 arguments.callee
    - 不能使用 arguments.caller
    - 禁止 this 指向全局变量
    - 不能使用 fn.caller 和 fn.arguments 获取函数调用的堆栈
    - 增加了保留字(比如 protected、static 和 interface)
    - 顶层的this指向undefined,不应该在顶层代码使用this

export 命令

  • 用于规定模块的对外接口,一个模块就是一个独立的文件,如果想从外部获取该模块的变量,需要使用 export 关键字输出该变量,可以做到动态更新,实时变化!
export var c = "1";  
// 或者  
var c = "1";  
var b = "2";  
export {c,b};  
// 输出函数或类  
export function sum(x,y){ return x+y };  
// 还可以重命名-可以改两次以上奥  
function v1(){};  
function v2(){};  
export { v1 as vA, v2 as vB, v2 as vC };  
// 如果export处于块级作用域的话会报错,必须放在模块顶层
function v(){ export default 'bar' // SyntaxError }

import 命令

  • 用于输入其他模块提供的功能
import { xxx } from 'url';

模块的整体加载

import * as NAME from 'URL';

export default 命令

  • 为模块指定默认输出
export default funtion () {  
    console.log('foo');  
}  

About

ES6-module的语法

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors