原生支持模块化了
ES6中新增的模块化,即从ES6开始,原生js支持模块化了,现在很多浏览器也支持模块化了。
- 模块化的两个概念
- 导出(export关键字):导出就是对外开放的,可以导出变量,常量,函数,对象等等。使用export关键字。放在export关键字后面的(即对外导出的)变量,常量,函数和对象,在其它js文件中可以使用,否则,其它js文件中是不能使用的。即只能内部使用的。
如:person.js文件(模块)里,如下:
//导出字符串
export var str = "hello";
//导出函数
export var fun = function(){
alert("我是函数");
}
//导出对象
export const p ={
"id":"007",
"name":"张三疯",
"eat":function(){
alert("吃");
ff();
}
}
//此函数没有使用export关键字导出,所以,只能在当前js文件内部使用
function ff(){
alert("我只能在当前js被使用");
}
【javaScript|JS中ES6的模块化】2.导入(import):导入就是把其它js文件引入到当前js文件里。使用关键字import。
在使用import导入(export导出的)时,要使用花括号,
如:import {str,fun,p} from './person.js';
在index.js文件中,引入模块person.js;
//导入时,需要使用{},这是解构赋值。
import {str,fun,p} from './person.js';
window.onload = function(){
document.getElementById("btn01").onclick = function(){
console.log(str);
fun();
console.log(p.id);
p.eat();
}
}
-
-
- 在html文件中引入index.js(注意: type="module")
注意:js中使用了模块化的关键字import,在引入时,script标签的type属性的值必须写成module。即:
- 在html文件中引入index.js(注意: type="module")
-
注意:测试以上代码时,google浏览器要求放在服务器上进行 ,否则,就会有跨域问题。
-
- export default和export 有什么区别:
- 、export与export default均可用于导出常量、函数、文件、模块等
- 、在一个文件或模块中,export可以有多个,export default仅有一个,而且export default在导出是不需要变量名,相当于匿名的。
- 、通过export方式导出,在导入时要加{ },export default则不需要。
代码示例:
模块定义:dog.js
export default {
"name":"大黄",
"eat":function(){
alert("吃");
}
}
导入模块:
import d from './dog.js';
window.onload = function(){
document.getElementById("btn01").onclick = function(){
console.log(d);
d.eat();
}
}
推荐阅读
- 编程语言|【程序源代码】驾校模拟考试系统
- vue.js|ES6模块化开发
- ES6新特性|ES6新特性-模块化(import/export)
- linux|阿里前端面试题(最全),持续更新中
- 跟着大佬学JavaScript之lodash防抖节流合并
- 代码实例效果精选|哈哈哈 原来使用jQuery+CSS就可以实现图片自动切换轮播效果是那么简单的事情 搞了个小米商城官网淡入淡出自动轮播图效果来看看也挺好
- 前端|SVG 在前端的7种使用方法,你还知道哪几种()
- 小程序|微信小程序双向数据绑定
- #|JavaScript高级(ES6)