Webpack笔记一

webpack

webpack是模块加载器兼打包工具,它可以把各种资源,如js、less/sass、图片等做为模块来使用和处理。
webpack的官网是:http://webpack.github.io/
文档地址是: http://webpack.github.io/docs/

安装

  1. 常规是使用npm的形式来进行:
    npm install webpack -g (全局安装)

  2. 安装完成可以使用:
    webpack -v(版本号)来校验是否安装成功

  3. 当然把依赖写入pagckage.json更贴合使用:
    npm init(创建pageage.json)

    npm install 模块名 -g(全局安装)

    npm install 模块名 -save(产品模式用,添加到了package.json中的dependencies下)

    npm install 模块名 -save-dev(开发模式用,添加到了package.json中的devDependencies下)

    安装成功后,当前目录下会出现一个node_modules的文件夹。

    npm update 模块名(更新模块)

    npm uninstall 模块名(卸载模块)

配置

配置的话每个项目里有一个webpack.config.js,它是一个配置项,就是告诉webpack它需要做什么。
此次配置包括如下:

webpack.config.js //基础配置
webpack-dev-server //自动刷新页面
html-webpack-plugin //自动生成页面

webpack打包DEMO

这里已裸奔的webpack为例,暂不使用vue-cli搭建出的。

按照上面步骤,全局安装webpack后创建一个demo的文件夹,文件夹里创建一个html(可以是文件夹,主要放准备给浏览器读取的数据,比如index.html)、一个文件夹(主要是存放原始数据和将要写的JavaScript模块)命名随意,这里以vue的index.html和app文件夹为例。

在app文件夹中建立两个js 起名随意,这里以app.js和index.js为例。

app.js(用来返回包含问候信息的html元素的函数)

module.exports = function() {
  var hello = document.createElement('div');
  hello.textContent = "Hello Everybody!";
  return hello;
};

index.js(用来把app.js返回的信息插入页面)

var hello = require('./app.js'); 
document.getElementById('test').appendChild(hello());

index.html(加载打包后的js文件)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>webpack test</title>
</head>
<body>
    <div id="test"></div>
</body>
<!-- webpack一会打包完成的js -->
<script src="build/build.js"></script> 
</html>

执行:webpack app/index.js build/build.js

2.webpack的配置

项目下建立一个webpack.config.js文件。
官方标配示例如下:

module.exports = {
    dvtool: //配置生成Source Maps,选择合适的选项
    plugins: //插件项
    entry: //页面入口文件配置
    output: //入口文件输出配置
        path: //定义输出文件路径
        filename: //指定打包文件名称
    module: //加载器配置,对模块的处理逻辑
    loaders: //定义了一些列的加载器
        test: //正则,匹配到文件的后缀名
        loader/loaders: //处理匹配到的文件
        include: //包含的文件夹
        exclude: //排除的文件夹
    resolve: //其它解决方案的配置
        extensions: //自动补全识别后缀
}

plugins

内置插件:通过在webpack配置中使用插件属性来将插件包含进你的项目中。

//webpack 应该在node_modules文件夹
//webpack-load-pluginds 调用后不需要require(plugins),在需要别的插件的时候webpack内部自动require();

var webpack = require("webpack");
//安装webpack-load-plugins后,下面就不用再require()插件了。
module.exports = {
    plugins: [
    //内置插件,内建plugins不需要require
        new webpack.ResolverPlugin([
            new webpack.ResolverPlugin.DirectoryDescriptionFilePlugin("bower.json", ["main"])], ["normal", "loader"])
    ]
}

其他插件:可以通过npm进行安装已经发布的插件。如果没有发布的也可以通过其他方式安装。

npm install component-webpack-plugin

使用方法如下:

//别人家的插件,你得需要require();
var ComponentPlugin = require("component-webpack-plugin");

module.exports = {
    plugins: [
        new ComponentPlugin();
    ]
}

如果是npm来安装第三方插件,建议使用webpack-load-plugins

npm install --save-dev webpack-load-plugins

使用时候在package.json文件里添加依赖:

{
    "devDependencies": {
        "clean-webpack-plugin": "*",
        "html-webpack-plugin": "*"
    }
}

在webpack.config.js文件中写入:

var webpack = require('webpack');
var webpackLoadPlugins = require('webpack-load-plugins');
var plugins = webpackLoadPlugins();

或者简写为:

var plugins = require('webpack-load-plugins')();

更详细的内容可参考npm关于插件的说明:https://www.npmjs.com/package/webpack-load-plugins

更多文章请移步 http://www.yuki.kim

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,099评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,473评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,229评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,570评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,427评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,335评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,737评论 3 386
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,392评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,693评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,730评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,512评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,349评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,750评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,017评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,290评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,706评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,904评论 2 335

推荐阅读更多精彩内容

  • 无意中看到zhangwnag大佬分享的webpack教程感觉受益匪浅,特此分享以备自己日后查看,也希望更多的人看到...
    小小字符阅读 8,125评论 7 35
  • 最近在学习 Webpack,网上大多数入门教程都是基于 Webpack 1.x 版本的,我学习 Webpack 的...
    My_Oh_My阅读 8,150评论 40 247
  • 前言 WebPack 是什么? WebPack 是什么,WebPack 可以看做是模块打包机:它做的事情是,分析你...
    Promise__阅读 1,116评论 3 12
  • GitChat技术杂谈 前言 本文较长,为了节省你的阅读时间,在文前列写作思路如下: 什么是 webpack,它要...
    萧玄辞阅读 12,655评论 7 110
  • 完成了 书院:共读页的制作与布局修改。读书流程的修复完善与一些样式变动。 Ios内嵌的配音首页作业报告与安卓作统一...
    LiLiLiH阅读 205评论 0 0