es6+最佳入门实践(13)
13.模块化
13.1.什么是模块化
模块化是一种处理复杂系统分解为更好的可管理模块的方式。通俗的讲就是把一个复杂的功能拆分成多个小功能,并且以一种良好的机制管理起来,这样就可以认为是模块化。就像作家把书分成很多章节来写一样,程序员写代码分模块来写也是一种良好的习惯。从本质上来讲,一个模块就是一堆代码而已
使用模块化方式写代码,有非常多的优点,例如,可维护性好、避免全局变量污染、可复用性好等,下面我们来看看es5中如何实现模块化封装
var module1 = (function () {
var _count = 0
var fn1 = function () {
alert(_count)
}
var fn2 = function () {
console.log(_count)
}
return {
fn1: fn1,
fn2: fn2
}
})()
module1.fn1() //0
module1.fn2() //0
console.log(module1._count); //undefined
13.2.环境准备
在具体写测试demo之前,我们需要准备一下环境
1.进入到项目目录,初始化项目
npm init -y
2.安装webpack和webpack-cli
npm install webpack webpack-cli -D
这里“-D”是“--save-dev”的简写
3.安装babel
npm install babel-core babel-loader babel-preset-env --save-dev
4.配置babel, 在项目目录下新建.babelrc文件,然后输入
{
"presets": ["env"]
}
4.测试环境是否成功,在项目下新建index.js,写入代码
()=>{console.log(1)}
5.使用webpack打包
./node_modules/.bin/webpack --mode development
13.3.export命令和import命令
模块功能主要由两个命令构成:export和import。export命令用于规定模块的对外接口,import命令用于输入其他模块提供的功能。通俗的讲export用来导出内容,import用来引入内容
1.导出和导入变量
我们新建一个modules目录,在下面新建一个文件a.js写相关代码
//导出变量
let username = 'xiaoqiang'
let password = '123'
export {username, password}
在index.js文件中引入a.js模块代码
//导入变量
import {username,password} from './modules/a.js'
console.log(username, password)
2.导入和导出函数
//导出函数
export function hello() {
return "hello nodeing"
}
//导入函数
import {hello} from './modules/a'
console.log(hello())
3.导入和导出类
//导出一个类
export class hello{
fn(){
console.log('hello world!!!')
}
}
//导入一个类
import {hello} from './modules/a'
console.log(hello)
let obj = new hello()
obj.fn()
注意1: 不要直接导出一个值
export 1 //错误
let m = 20
export m //错误
注意2: 不要直接导出函数或者类
function fn(){}
export fn
class hello{}
export hello
注意3: export语句要在模块最顶层,放在块级作用域内会报错
{
export let a=10 //报错
}
注意4: 可以批量接收导出的内容
//导出变量、函数、类
export class hello{
fn(){
console.log('hello world!!!')
}
}
export let A = 10
export function Fn() {
console.log(111)
}
//批量导入内容,所有的变量 类 函数等都挂载到amodule身上
import * as amodule from './modules/a'
console.log(amodule.A, amodule.Fn, amodule.hello)
13.3.export default命令
从前面的例子中,我们需要思考一个问题,每次使用一个模块的时候,我们都需要知道这个模块里面到底有哪些变量、函数、类,我们要根据这些类名来导入,这样方便么?为了更方便的写代码,我们可以使用export default命令,为模块指定默认输出
//默认输出变量
let a = 10
export default a
注意: 不要写成这样
export default let a = 10 // 报错
//导入模块
import aa from './modules/a'
console.log(aa)
使用export default命令导出,再导入的时候不用加括号{}, 名字可以自定义了
推荐的模块导入导出方式:
//导出内容
let a = 10
function Fn() {
console.log(111)
}
class Hello{
Fn2(){
console.log(111)
}
}
export default {
a,
Fn,
Hello
}
//导入内容
import aa from './modules/a'
console.log(aa)
视频教程地址:http://edu.nodeing.com/course/50
es6+最佳入门实践(13)的更多相关文章
- es6+最佳入门实践(14)
14.模版字符串 模版字符串(template string)是增强版的字符串,定义一个模版字符串需要用到反引号 let s = `这是一个模版字符串` console.log(s) 14.1.模版字 ...
- es6+最佳入门实践(12)
12.class基础用法和继承 12.1.class基础语法 在es5中,面向对象我们通常写成这样 function Person(name,age) { this.name = name; this ...
- es6+最佳入门实践(10)
10.Generator 10.1.Generator是什么? Generator函数是ES6提供的一种异步编程解决方案.在它的内部封装了多个状态,因此,又可以理解为一种状态机,执行Generator ...
- es6+最佳入门实践(9)
9.Iterator和for...of 9.1.Iterator是什么? Iterator又叫做迭代器,它是一种接口,为各种不同的数据结构提供统一的访问机制.这里说的接口可以形象的理解为USB接口,有 ...
- es6+最佳入门实践(8)
8.Promise 8.1.什么是异步? 要理解异步,首先,从同步代码开始说 alert(1) alert(2) 像上面的代码,执行顺序是从上到下,先后弹出1和2,这种代码叫做同步代码 alert(0 ...
- es6+最佳入门实践(7)
7.set和map数据结构 7.1.什么是set? Set就是集合,集合是由一组无序且唯一的项组成,在es6中新增了set这种数据结构,有点类似于数组,但是它的元素是唯一的,没有重复 let st = ...
- es6+最佳入门实践(6)
6.Symbol用法 6.1.什么是Symbol? Symbol是es6中一种新增加的数据类型,它表示独一无二的值.es5中我们把数据类型分为基本数据类型(字符串.数字.布尔.undefined.nu ...
- es6+最佳入门实践(5)
5.对象扩展 5.1.对象简写 在es5中,有这样一种写法 var name = "xiaoqiang"; var age = 12; var obj = { name : nam ...
- es6+最佳入门实践(4)
4.函数扩展 4.1.参数默认值 默认参数就是当用户没有传值的时候函数内部默认使用的值,在es5中我们通过逻辑运算符||来实现 function Fn(a, b) { b = b || "n ...
随机推荐
- python基础集结号
Python 号称是最接近人工智能的语言,因为它的动态便捷性和灵活的三方扩展,成就了它在人工智能领域的丰碑 走进Python,靠近人工智能 一.编程语言Python的基础 之 "浅入浅出&q ...
- 11 TCP实现QQ聊天
1.客户端参考代码 #coding=utf-8 from socket import * # 创建socket tcpClientSocket = socket(AF_INET, SOCK_STREA ...
- P1794 装备运输_NOI导刊2010提高(04)
P1794 装备运输_NOI导刊2010提高(04) 题目描述 德国放松对英国的进攻后,把矛头指向了东边——苏联.1943年初,东线的战斗进行到白热化阶段.据可靠情报,90余万德国军队在库尔斯克准备发 ...
- 什么鬼,又不知道怎么命名class了
什么鬼,又不知道怎么命名class了 2015/10/25 · CSS · class 分享到:5 原文出处: 结一(@结一w3cplus) 相信写css的人都会遇到下面的问题: 糟糕,怎么命名 ...
- Vuex实践
本文来自网易云社区 作者:刘凌阳 前言 2017年对于Vue注定是不平凡的一年.凭借着自身简介.轻量.快速等特点,Vue俨然成为最火的前端MVVM开发框架.随着Vue2.0的release,越来越多的 ...
- iOS中如何根据UIView获取所在的UIViewController
原理 Responder Chain 事件的响应者链 大概的传递规则就是从视图顶层的UIView向下到UIViewController再到RootViewController再到Window最后到Ap ...
- 『AngularJS』Service
理解Angular 服务 什么是Angular Service Angular 服务是为web应用执行特定任务的单例对象或方法. 注:如果组件是为了内容呈现的功能复用,那么服务就是为组件进行功能复用. ...
- npx 命令介绍
这个是在 npmv5.2.0引入的一条命令(查看),引入这个命令的目的是为了提升开发者使用包内提供的命令行工具的体验. 为什么引入这个命令 举个例子,我们开发中要运行 parcel 命令来打包:par ...
- Qt 使用irrlicht(鬼火)3D引擎
项目中需要加载简单的3D场景.资深老前辈推荐使用开源小巧的引擎irrlicht. 关于irrlicht,来之百度百科 Irrlicht引擎是一个用C++书写的高性能实时的3D引擎,可以应用于C++程序 ...
- python 基础篇 11 函数进阶----装饰器
11. 前⽅⾼能-装饰器初识本节主要内容:1. 函数名的运⽤, 第⼀类对象2. 闭包3. 装饰器初识 一:函数名的运用: 函数名是一个变量,但他是一个特殊变量,加上括号可以执行函数. ⼆. 闭包什么是 ...