• webpack入坑之旅(一)入门安装


    学习一个新的东西,首先第一步就是安装,有时候会遇到各种奇葩的问题

    至于什么是webpack我这里就不介绍了,请参考官网:https://github.com/webpack/webpack

    安装

    前提:因为webpack是一个基于node的项目,所以首先需要确保你的电脑里面已经安装了node.js,以及npm。在这里我使用的版本是:node:v5.8.0 ,npm:3.7.3,若是版本问题,请更新到最新版。
    若是有出现npm安装过慢的情况,可以使用nrm这个项目来进行npm源地址的切换。

    首先我们直接进行全局的安装,运行如下命令:npm install webpack -g,可能需要一点时间。

    安装成功后,在命令行输入webpack -h即可查看当前安装的版本信息。以及可以使用的指令。

    当然,我们都应该将webapck安装到当前的项目依赖中,此时就可以使用项目的本这样就可以使用项目本地版本的 Webpack。

    # 确保已经进入项目目录
    # 确定已经有 package.json,没有就通过
    npm init 
    # 创建,直接一路回车就好,后面再来详细说里面的内容。
    # 安装 webpack 依赖
    npm install webpack --save-dev
    # 简单的写法:-_-,缩写形式 
    npm i webpack -D
    # –save:模块名将被添加到dependencies,可以简化为参数-S。
    # –save-dev: 模块名将被添加到devDependencies,可以简化为参数-D。
    

      

    安装好之后我们的package.json的目录应该是这样的:

    {
      "name": "webpack-learn",
      "version": "1.0.0",
      "description": "learn",
      "main": "index.js",
      "scripts": {
        "test": "echo "Error: no test specified" && exit 1"
      },
      "keywords": [
        "learn"
      ],
      "author": "lanyan",
      "license": "ISC"
    }
    

      

    首先创建一个静态页面 index.html 和一个 JS 入口文件 entry.js,(这里你想用什么名字都可以,只需要在打包的时候读取文件为该名字就好,不过,到时候就知道这个名字的含义啦!):

    <html>
    <head>
        <meta charset="utf-8">
    </head>
    <body>
        <h1 id="app"></h1>
        <script src="bundle.js"></script>
        <!-- 注意这里引入的不是我们创建的文件,而是用webpack生成的文件 -->
    </body>
    </html>
    

      

    /*** entry.js ***/
    document.getElementById('app').innerHTML="这是我第一个打包成功的程序";
    

      

    文件都已经创建成功了,那么就开始我们的打包吧!

    webpack entry.js bundle.js

    在浏览器中打开index.html,就能看到我们设置的文字啦!:这是我第一个打包成功的程序

    这么简单的功能直接在html中引入不就好了吗?确实是这样的,不过我们这才刚刚开始嘛,不要急。

    下面我们再来增加一个文件,名为first.js内容如下:

    var h2= document.createElement("h2")
    h2.innerHTML="不是吧,那么快第二个打包程序啦!";
    document.body.appendChild(h2);
    

      更改 entry.js:

    document.getElementById('app').innerHTML="这是我第一个打包成功的程序";
    //添加
    require("./first.js");
    

      再来进行一次重复的工作,再打包一次。webpack entry.js bundle.js,如果成功,打包过程会显示日志:

    Hash: b1cfe7ff9d75ce235dc9
    Version: webpack 1.12.14
    Time: 54ms
        Asset     Size  Chunks             Chunk Names
    bundle.js  1.82 kB       0  [emitted]  main
       [0] ./entry.js 208 bytes {0} [built]
       [1] ./first.js 145 bytes {0} [built]
    

      

    Webpack 会分析入口文件,解析包含依赖关系的各个文件。这些文件(模块)都打包到 bundle.js 。Webpack 会给每个模块分配一个唯一的 id 并通过这个 id 索引和访问模块。在页面启动时,会先执行 entry.js 中的代码,其它模块会在运行 require 的时候再执行。

    刷新浏览器,可以发现我们的刚刚的代码已经生效,又有了新的文字出现。

  • 相关阅读:
    模拟赛20181101 雅礼 Wearry 施工 蔬菜 联盟
    模拟赛20181031 雅礼 Wearry 养花 折射 画作
    set/priority_queue的运算符重载
    set的完整用法
    最长公共上升子序列 O(n^2)
    无向图边双联通分量 tarjan 模板
    ID 迭代加深搜索 模板 埃及分数
    树上背包DP Luogu P2014 选课
    A* 第k短路
    [POJ3468]关于整数的简单题 (你想要的)树状数组区间修改区间查询
  • 原文地址:https://www.cnblogs.com/laneyfu/p/6130577.html
Copyright © 2020-2023  润新知