• Webpack 入门


    Webpack 入门

    **Tip:**

    本文所有示例基于 webpack2。

    文中的示例代码说明可以参考:Webpack 示例代码说明

    安装

    本地安装

    $ npm install --save-dev webpack
    $ npm install --save-dev webpack@<version>

    如果你在项目中使用了 npm ,npm 首先会在本地模块中寻找 webpack。这是一个实用的小技巧。

    "scripts": {
        "start": "webpack --config mywebpack.config.js"
    }

    上面是 npm 的标准配置,也是我们推荐的实践。

     当你在本地安装 webpack 后,你能够从 node_modules/.bin/webpack 访问它的 bin 版本。

    全局安装

    $ npm install --global webpack

    webpack 命令现在可以全局执行了。

    创建一个 bundle 文件

    创建一个 app/index.js 文件。

    document.write('<h1>Hello World</h1>');

    创建一个 index.html 文件。

    <html>
    <body>
    <script type="text/javascript" src="./dist/bundle.js"></script>
    </body>
    </html>

    执行命令

    $ webpack ./app/index.js ./dist/bundle.js

    这条命令的第一个参数为输入文件,第二个参数为输出文件。

    会在目录下生成一个 dist/bundle.js 文件,它已打包所需的所有代码的输出文件。

    在浏览器中打开 index.html 文件。

    完整示例: (DEMO00)

    webpack.config.js

    webpack.config.js 为 webpack 默认的配置文件,当执行 webpack 命令时,webpack 会在当前目录下自动搜索 webpack.config.js 文件。

    单入口(Entry)

    基于 (DEMO00) 的代码,新建一个 webpack.config.js 文件,内容如下:

    const path = require('path');
    
    module.exports = {
    
      // 这里应用程序开始执行
      // webpack 开始打包
      entry: "./app/index.js",
    
      // webpack 如何输出结果的相关选项
      output: {
        // 所有输出文件的目标路径
        // 必须是绝对路径(使用 Node.js 的 path 模块)
        path: path.resolve(__dirname, "dist"),
    
        // 「入口分块(entry chunk)」的文件名模板(出口分块?)
        filename: "bundle.js",
      }
    };

    执行命令

    $ webpack

    在浏览器中打开 index.html 文件。

    完整示例: (DEMO01)

    多入口(Entry)

    如果有多个入口文件怎么办?很简单,我们来看一个示例:

    新建 app/about.js 文件

    document.write('<h2>ABOUT</h2>');

    新建 app/home.js 文件

    document.write('<h1>HOME</h1>');

    新建 index.html 文件

    <html>
    <body>
    <script src="dist/home.js"></script>
    <script src="dist/about.js"></script>
    </body>
    </html>

    新建 webpack.config.js 文件

    const path = require('path');
    
    module.exports = {
    
      // 这里应用程序开始执行
      // webpack 开始打包
      // 本例中 entry 为多入口
      entry: {
        home: './app/home.js',
        about: './app/about.js'
      },
    
      // webpack 如何输出结果的相关选项
      output: {
        // 所有输出文件的目标路径
        // 必须是绝对路径(使用 Node.js 的 path 模块)
        path: path.resolve(__dirname, "dist"),
    
        // 「入口分块(entry chunk)」的文件名模板(出口分块?)
        // filename: "bundle.js", // 用于多个入口点(entry point)(出口点?)
        filename: "[name].js", // 用于多个入口点(entry point)(出口点?)
        // filename: "[chunkhash].js", // 用于长效缓存
        // filename: "[name].[chunkhash].js", // 用于长效缓存
      }
    };

    执行命令

    $ webpack

    在浏览器中打开 index.html 文件。

    完整示例: (DEMO02)

    Webpack 系列教程

    欢迎阅读其它内容:

    作者:静默虚空
    欢迎任何形式的转载,但请务必注明出处。
    限于本人水平,如果文章和代码有表述不当之处,还请不吝赐教。

  • 相关阅读:
    MSN、易趣、大旗被挂马 用户浏览后感染机器狗病毒 狼人:
    世界最大漏洞数据库发布最新研究报告 狼人:
    五角大楼最昂贵武器发展项目遭到黑客攻击 狼人:
    RSA呼吁厂商“创造性协作” 共同反击网络威胁 狼人:
    RSA2009:云计算服务如何保证安全? 狼人:
    黑客工具可将恶意软件隐藏于.Net框架 狼人:
    RSA安全大会将亮相25款热门安全产品 狼人:
    目录访问共享C#怎么访问共享目录
    代码下行Jquery结合Ajax和Web服务使用三层架构实现无刷新分页
    输出次数HDU2192:MagicBuilding
  • 原文地址:https://www.cnblogs.com/wangchaoyuana/p/7507460.html
Copyright © 2020-2023  润新知