ES 之 模块

Posted hkui

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ES 之 模块相关的知识,希望对你有一定的参考价值。

查看webpack 版本
1.npm info webpack
2.webpack -v 

如果没有出现,npm install --global webpack-cli,因为
注意:webpack 4x以上,webpack将命令相关的内容都放到了webpack-cli,所以还需要安装webpack-cli

之后再webpack -v
npm init

生成package.json文件

npm install lodash --save
会把模块写入到依赖

"dependencies": {
    "lodash": "^4.17.15"
}
npm install moment --save

模块清理
rm -rf node_modules
rm -rf package-lock.json
npm cache clear --force
npm install
webpack
安装在开发依赖里
npm install webpack --save-dev

babel
npm install --save-dev babel-loader @babel/core  @babel/preset-env
在项目目录下新建 webpack.config.js
const TerserPlugin = require(‘terser-webpack-plugin‘);

module.exports={
    devtool:‘source-map‘,
    entry:‘./app.js‘,
    output:{
        filename:‘./bundle.js‘
    },
    optimization: {
        minimizer: [
            new TerserPlugin({
                cache: true, // 开启缓存
                parallel: true, // 支持多进程
                sourceMap: true,
            }),
        ]
    },

    module:{
        rules:[
            {
                test:/.js$/,
                use:[
                    {
                        loader:‘babel-loader‘,
                        options:{presets:[‘@babel/preset-env‘]}
                    },
                ]
            }
        ]
    },
    mode:‘development‘
}

修改package.json
  "dependencies": {
    "lodash": "^4.17.15",
    "moment": "^2.24.0"
  },
  "devDependencies": {
    "@babel/core": "^7.8.4",
    "@babel/preset-env": "^7.8.4",
    "babel-loader": "^8.0.6",
    "webpack": "^4.41.6",
    "webpack-cli": "^3.3.11"
  }
入口文件app.js
import { uniq } from ‘lodash‘;
import moment from ‘moment‘;

const arr=[1,2,2,3,3,4,5];
console.log(arr,uniq(arr))

新建一个自己的模块

默认导出和命名导出
  • 默认导出一个模块只能有1个,导入时可选定任意名
  • 命名导出 则名称固定
1.默认导出

config.js

const apiKey=‘123‘;
export default apiKey

入口文件app.js

import  apiKey from ‘./config‘;
console.log(apiKey)
//或者------------------
import  code from ‘./config‘;
console.log(code)
2.命名导出
export {apiKey as key,greet} //导出多个
import {key as mykey,greet } from ‘./config‘

import 默认的,{命名1,命名2} from ‘相对路径‘

config.js(模块文件)

const apiKey=‘123‘;
export default apiKey
export const age = 20;

function intro(name){
    return `${name}`;
}
export function greet(name) {
    console.log(`hello ${intro(name)}`)
}

app.js(入口文件)

import { uniq } from ‘lodash‘;

import  apiKey,{age,greet} from ‘./config‘;
console.log(apiKey,age)
greet(‘hk‘);

const arr=[1,2,2,3,3,4,5];
console.log(uniq(arr))

以上是关于ES 之 模块的主要内容,如果未能解决你的问题,请参考以下文章

ES6 模块串联

ES6模块之export和import教程

OpenGL ES之“深度测试”与“模板测试”的使用流程

ES7-Es8 js代码片段

VUE学习笔记:13.模块化开发之:为什么需要模块化,CommonJS,ES6中的模块化(了解)

python之模块和包