最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Webpack系列(二):核心概念

    正文概述 掘金(snailsmail)   2021-02-03   628

    Webpack系列(二):核心概念

    1.零配置

    - 创建文件夹 coremodule

    - npm init -y 生成默认内容的 package.json 文件

    - npm install -D webpack@4.43.0 webpack-cli@3.3.12 安装依赖

    - 根目录下新建 src 文件夹,在 src 下新建 index.js 作为 webpack 的入口文件

    - 使用 npx webpack 进行打包

    Webpack系列(二):核心概念

    注意:若 src 下没有 index.js 文件,则会报错,因为这是 webpack 默认的入口文件

    零配置只是最基础的配置项,一般项目都是需要自行添加配置的.

    2.核心概念

    Webpack V4文档

    • entry 打包入口文件
    • output 打包输出文件
    • loader 模块解析
    • plugin 插件
    • mode 打包模式

    3.分析及使用

    3.1.还原零配置内容

            根目录下创建文件 webpack.config.js,webpack 默认的打包配置文件是指向 webpack.config.js 的,若是不创建 webpack.config.js 文件,可在执行打包命令后添加 --config xxx 指向新的配置文件

    -   根目录下新建 config.js,并添加以下内容:

    const path = require('path')
    
    module.exports = {
        entry: './src/index.js',
        output: {
            path: path.resolve(__dirname, 'dist'),
            filename: 'bundle.js'
        }
    }
    

    -  使用 npx webpack --config config.js 进行打包

    Webpack系列(二):核心概念

    打包结果信息零配置打包结果信息一致.

    3.2.entry

    webpack 的入口起点,可指定多个或一个,默认值是 ./src/indexl.js

    module.exports = {
        entry: './path/to/your/entry/file.js'
    }
    

    3.3.output

    webpack 的输出对象,指示 webpack 如何输出,那里输出,以及输出什么,默认值是 ./dist/main.js,其它的生成文件默认放置在 dist 文件夹.

    const path = require('path')
    
    module.exports = {
        output: {
           path: path.resolve(__dirname. 'dist'),
           filename: 'your-webpack.bundle.js'
        }
    }
    

    3.4.loader

    webpack 只能处理JavaScriptJSON 文件,而 loader 可以让 webpack 能够处理其它类型的文件,并将它们转化为有效模块. loader 是在 module 里的  rules 属性中的,配置 loader 需要两个必须属性:

    -   test 属性,指定需要化的某类文件转换

    - use 属性,指定需要进行转换对应的loader

    module.exports = {
        module: {
            rules: [
                {
                    test: /\.css$/,
                    use: ['style-loader', 'css-loader']
                }
            ]
        }
    }
    

    3.5.plugin

    插件用于执行范围更广的任务,例如:打包优化,资源管理,注入环境变量.使用插件时,需要使用 require() 导入,并使用 new 来创建它的一个实例.

    html-webpack-plugin 为例,在输出文件夹中自动生成 index.html 文件

    -    使用 npm install -D html-webpack-plugin 命令安装插件
    -webpack配置文件中添加一下内容

    const HtmlWebpackPlugin = require('html-webpack-plugin')
    
    module.exports = {
        plugins: [
            new HtmlWebpackPlugin({
                title: 'index页面',
                template: './src/index.html'
            })
        ]
    }
    

    Webpack系列(二):核心概念

    输出文件夹中,会出现多个不是本次打包输出的文件,可使用 clean-webpack-plugin 来清除dist目录打包前遗留的文件,先在开发环境依赖中安装,然后在配置文件中添加一下代码:

    const { CleanWebpackPlugin } = require('clean-webpack-plugin')
    
    module.exports = {
        plugins: [
            new CleanWebpackPlugin()
        ]
    }
    

    3.6.mode

    webpack 的打包模式,有 none, developmentproduction(默认)

    Webpack系列(二):核心概念

    4.链接

    github地址


    起源地下载网 » Webpack系列(二):核心概念

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元