1.安装webpack

npm install webpack -g

2.进入项目目录,初始化

npm init

3.将webpack安装到项目依赖中

npm install webpack --save-dev

4.创建一个webpack.config.js配置文件

module.exports = {

  // 需要编译的文件
  entry:{
    index1:'./src/index1.js',
    index2:'./src/index2.js'
  },

  // 编译配置项
  output:{

    // 输出到哪个目录
    path:'./dire',

    // 文件名 [name]会根据entry的键名来取值
    filename:'[name].js'
  }
};

目录结构:

5.cmd中输入:webpack

结果会生成一个dire目录。

OK,完成。

我们看看里面生成的代码。

乱七八糟的,如果想去掉这些可以这样。

var webpack = require('webpack');

module.exports = {
  entry:{
    index1:'./src/index1.js',
    index2:'./src/index2.js'
  },
  plugins:[
    new webpack.optimize.UglifyJsPlugin()
  ],
  output:{
    path:'./dire',
    filename:'[name].js'
  }
};

好像没啥用对吧,我们可以这样。

webpack小试身手,模块化开发。

目录结构

module.exports = {
  entry:'./main.js',
  plugins:[
    new webpack.optimize.UglifyJsPlugin()
  ],
  output:{
    path:'./dire',
    filename:'main.js'
  }
};

这里将main.js做为主模块,我们可以在main.js里面将需要用到的js文件通过require引入进来,达到模块化的需求,这个require的用法和nodejs一样。

当然你可以划分成多个模块,你只需要更改一下这个。

module.exports = {
  entry:{

    xx:'./xx/xx.js',

    xx:'./xx/xx.js'

    .......

  },
  plugins:[
    new webpack.optimize.UglifyJsPlugin()
  ],
  output:{
    path:'./dire',
    filename:'[name].js'
  }
};

这样你就可以根据不同模块编写JS代码了。真不错。

但这都只是冰山一角,来看看webpack更强大的功能。

在main.js中导入css文件。

main:require('./src/index.css');

但是发现报错了,我们需要配置一下webpack.config.js

编译css

var webpack = require('webpack');

module.exports = {
  entry:'./main.js',
  plugins:[
    new webpack.optimize.UglifyJsPlugin({
      compress:{

        //去除控制台错误
        warnings:false
      }
    })
  ],
  output:{
    path:'./dire',
    filename:'main.js'
  },
  module:{
    loaders:[
      {test:/\.css$/,loader:'style-loader!css-loader'}
    ]
  }
};

还得安装一下

npm install style-loader css-loader --save-dev

在main.js里面使用less文件。

require('./src/index.css');

require('./src/less.less');

需要进行如下配置:

loaders:[
  { test: /\.less$/, loader: 'style-loader!css-loader!less-loader' },
  { test: /\.css$/, loader: 'style-loader!css-loader' }
]

还得安装style-loader,css-loader,less-loader

npm install style-loader css-loader less-loader --save-dev

我安装完,webpack编译less文件的时候发现报错了。原来是还得安装一下less.

npm install less --save-dev

来看一下页面的效果:

我们用require过来的css文件变成style样式。

除了这个,我们还可以用来处理图片,将图片转成base64

main.js

require('./src/index.css');

require('./src/less.less');

var img = document.createElement('img');
img.src = require('./src/baidu.png');

var box = document.getElementById('box');
box.appendChild(img);

webpack.config.js

  

loaders:[
  { test: /\.less$/, loader: 'style-loader!css-loader!less-loader' },
  { test: /\.css$/, loader: 'style-loader!css-loader' },
  { test: /\.(png|jpg)$/, loader: 'url-loader?limit=8192' }
]

  

limit:表示图片小于多少就转成base64格式的图片。

使用前我们还得安装一下url-loader

npm install url-loader --save-dev

webpack

看看效果

生成base64位了噢。

在css,less中都是可以使用的噢。

less代码

ul{
  li{
    width:200px;
    height:200px;
    color:red;
    font-size:18px;
    background:url(./baidu.png) no-repeat;
  }
}

webpack实在太棒了。

如果你想编译其他格式的文件使用方法都差不多,这里就不试了。

通过webpack --watch监听文件变化自动打包。

webpack学习笔记的更多相关文章

  1. 【原】webpack学习笔记

    之前在react的项目中有用过webpack,不过没有认真的去研究,这段时间又重新好好的学习一下webpack,发觉 webpack是一个很强大的东西.而且很好用,方便,接下来主要是做一下学习的笔记 ...

  2. 更博不能忘——webpack学习笔记

    webpack是前端构建系统就像grunt和gulp(之前有学习过grunt所以也就大概明白webpack是个什么东西),所以说前端技术大部分还真是相通的,现在觉得当时多看的东西并不白费,虽然长时间不 ...

  3. webpack学习笔记(二)-- 初学者常见问题及解决方法

    这篇文章是webpack学习第二篇,主要罗列了本人在实际操作中遇到的一些问题及其解决方法,仅供参考,欢迎提出不同意见. 注:本文假设读者已有webpack方面相关知识,故文中涉及到的专有名词不做另外解 ...

  4. webpack学习笔记一:安装webpack、webpack-dev-server、内存加载js和html文件、loader处理非js文件

    一 .webpack学习环境准备: 1:window系统 2:安装node.js  官方网址 下载好后下一步下一步安装即可 安装步骤略过....... 3:nrm的安装 打开cmd命令控制台 输入:n ...

  5. Webpack学习笔记九 webpack优化总结

    webpack 优化笔记 webpack4 自带的优化包括 swingTree(摇摆树)和作用域提升 swingTree 比如入口文件 index.js引入通用方法 util, 里面有 10个方法, ...

  6. Webpack学习笔记一:What is webpack

      #,Loaders干嘛的,webpack can only process JavaScript natively, but loaders are used to transform other ...

  7. webpack学习笔记—webpack安装、基本配置

    文章结构: 什么是webpack? 安装webpack 'webpack基本配置 一.什么是webpack? 在学习react时发现大部分文章都是react和webpack结合使用的,所以在学reac ...

  8. 【webpack学习笔记】a04-建立开发环境

    开发环境就是在开发过程中为了方便配置的环境,生产环境就是开发完成即将上线的情况. 好了,说了句废话,切入正题. 在开发时,打包后的文件压缩成一团,报错调试的时候傻眼了有木有?每次做出修改需要到浏览器查 ...

  9. Webpack 学习笔记总结

    Webpack安装 Linux系统默认已经安装了node&npm,但版本比较低,而且没法升级,可以重新下载Node然后通过软链接替换系统自带的node和npm; ln -s /path_to/ ...

  10. webpack学习笔记丁点积累

    webpack是什么? https://webpack.js.org/concepts/ https://code.tutsplus.com/tutorials/introduction-to-web ...

随机推荐

  1. [UCSD白板题] Points and Segments

    Problem Introduction The goal in this problem is given a set of segments on a line and a set of poin ...

  2. javascript基础知识-类和模块

    在JavaScript中可以定义对象的类,让每个对象都共享这些属性. 在JavaScript中,类的实现是基于其原型继承机制的.如果两个实例都从同一个原型对象上继承了属性,我们就说它们是同一个类的实例 ...

  3. 一步一步hadoop安装

    部署hadoop集群 1.下载jdk1.6,从http://www.oracle.com/technetwork/java/javase/downloads/java-archive-download ...

  4. 重新开源UDS

    这个题目起得很纠结. 因为很多人都知道UDS本来就是开源,我只不过改了一些东西,然后重新发布,所以不算重新开源. 要说重新发布也不对.因为老早这东西就发布了. 最后我想,这个东西已经很久没更新过了,也 ...

  5. C++混合编程之idlcpp教程Lua篇(9)

    上一篇在这 C++混合编程之idlcpp教程Lua篇(8) 第一篇在这 C++混合编程之idlcpp教程(一) 与前面的工程相比,工程LuaTutorial7中除了四个文件LuaTutorial7.c ...

  6. Mac OS X 10.9.3 UI 设置界面无法设置时区解决

    10.9.3 在选项设置里无法设置时区,表现为选择时区的点的位置后无法保存,导致系统时间错乱,解决方法是用终端设置: sudo systemsetup -gettimezone sudo system ...

  7. Invalidate,Update与Refresh的区别

    在做Windows Forms开发的时候,免不了需要手动刷新窗口,以重绘所需更改的控件,或其它什么的.当出现这类需求时,你有三个选择,使用Invalidate,Update或者Refresh方法. I ...

  8. Lucene.net 实现近实时搜索(NRT)和增量索引

    Lucene做站内搜索的时候经常会遇到实时搜索的应用场景,比如用户搜索的功能.实现实时搜索,最普通的做法是,添加新的document之后,调用 IndexWriter 的 Commit 方法把内存中的 ...

  9. MVC使用ASP.NET Identity 2.0实现用户身份安全相关功能,比如通过短信或邮件发送安全码,账户锁定等

    本文体验在MVC中使用ASP.NET Identity 2.0,体验与用户身份安全有关的功能: →install-package Microsoft.AspNet.Identity.Samples - ...

  10. Intellij修改archetype Plugin配置

    Maven archetype plugin为我们提供了方便的创建 project功能,Archtype指我们项目的骨架,作为项目的脚手架. 如fornt end的yo之类.我们能够通过简单的一行控制 ...