首页 > Web开发 > 详细

【Webpack】学习随笔

时间:2017-04-26 23:38:02      阅读:654      评论:0      收藏:0      [点我收藏+]

参考链接:http://www.runoob.com/w3cnote/webpack-tutorial.html

Webpack 是一个前端资源加载/打包工具。

Webpack 可以将多种静态资源 js、css、less 转换成一个静态文件,减少了页面的请求。

1.1使用淘宝 NPM 镜像

$ npm install -g cnpm --registry=https://registry.npm.taobao.org

1.2使用 cnpm 安装 webpack

cnpm install webpack -g

1.3接下来我们创建一个目录 app

mkdir app

技术分享

1.4在 app 目录下添加 runoob1.js 文件,代码如下:

document.write("It works.");

1.5在 app 目录下添加 index.html 文件,代码如下:

<html>
    <head>
        <meta charset="utf-8">
    </head>
    <body>
        <script type="text/javascript" src="bundle.js" charset="utf-8"></script>
    </body>
</html>

技术分享

1.6接下来我们使用 webpack 命令来打包(先进入app文件夹)

技术分享

1.7在浏览器访问,输出结果如下所示

技术分享

1.8接下来我们创建另外一个 js 文件 runoob2.js,代码如下所示

module.exports = "It works from runoob2.js.";

1.9更新 runoob1.js 文件,代码如下

document.write(require("./runoob2.js"));

1.10接下来我们使用 webpack 命令来打包

webpack runoob1.js bundle.js

技术分享

技术分享

在页面启动时,会先执行 runoob1.js 中的代码,其它模块会在运行 require 的时候再执行。

LOADER

Webpack 本身只能处理 JavaScript 模块,如果要处理其他类型的文件,就需要使用 loader 进行转换

2.1使用以下命令来安装 css-loader 和 style-loader(全局安装需要参数 -g)

cnpm install css-loader style-loader

技术分享

2.2接下来创建一个 style.css 文件,代码如下

body {
    background: yellow;
}

2.3修改 runoob1.js 文件,代码如下:(打包后报错!)

require("!style!css!./style.css");
document.write(require("./runoob2.js"));

技术分享

2.4采用配置文件的方法,创建 webpack.config.js 文件,代码如下所示(其中红色部分,必须加-loader,否则报错!!

module.exports = {
    entry: "./runoob1.js",
    output: {
        path: __dirname,
        filename: "bundle.js"
    },
    module: {
        loaders: [
            { test: /\.css$/, loader: "style-loader!css-loader" }
        ]
    }
};

2.5打包成功

技术分享

2.6浏览器显示结果

技术分享

插件

插件在 webpack 的配置信息 plugins 选项中指定,用于完成一些 loader 不能完成的工作。

使用内置插件需要通过以下命令来安装

cnpm install webpack --save-dev

比如我们可以安装内置的 BannerPlugin 插件,用于在文件头部输出一些注释信息。

修改 webpack.config.js

var webpack=require(‘webpack‘);
 
module.exports = {
    entry: "./runoob1.js",
    output: {
        path: __dirname,
        filename: "bundle.js"
    },
    module: {
        loaders: [
            { test: /\.css$/, loader: "style-loader!css-loader" }
        ]
    },
    plugins:[
    new webpack.BannerPlugin(‘菜鸟教程 webpack 实例‘)
    ]
};

进入app文件执行webpack

技术分享

打开 bundle.js,可以看到文件头部出现了我们指定的注释信息

技术分享

【Webpack】学习随笔

原文:http://www.cnblogs.com/yujihang/p/6771506.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!