Webpack

Demos

https://github.com/ruanyf/webpack-demos

Docs

https://webpack.github.io/docs/?utm_source=github&utm_medium=readme&utm_campaign=trdr

Webpack可以做什么

  • 支持CMD AMD (Gulp还需要browserify才能CMD)
  • 模块加载器 插件机制 (典型的模块加载器babel-loader)
  • 可以通过配置打包成多个文件 (充分利用浏览器缓存功能)
  • 样式 图片等静态资源都可以视作模块 (任何的文件都能被 require)
  • 内置source-map

第一个例子

首先npm install -g webpack

和Gulp一样 有一个入口执行文件 webpack.config.js

module.exports = {
entry: './main.js',
output: {
filename: 'bundle.js'
}
};

如何运行它

$ webpack // 最基本的启动webpack方法
$ webpack -w // 提供watch方法,实时进行打包更新(包括被依赖的文件的改动)
$ webpack -p // 对打包后的文件进行压缩,提供production
$ webpack -d // 提供source map,方便调试

sourcemap对应的文件将会在 webpack:// 下面的一个 . 目录中

ES6

想要把ES6转为ES5 需要babel

当然Gulp也有babel 为什么网上都是webpack呢

对于import export这种 babel后会是 require(...)

浏览器是不认识require的 若用gulp还要再用browserify

但是wepack可以直接把require编译为浏览器可执行的语句

webpack.config.js

module.exports = {
// entry: './main.jsx', //不能直接写main.jsx //当前目录下必须加上 ./ //否则提示找不到文件
entry: './f2.js',
output: {
filename: 'bundle.js'
},
module: {
loaders:[
{ test: /\.js[x]?$/, exclude: /node_modules/, loader: 'babel-loader' },
]
}
};

f2.js

import f1 from './f1.js';
console.log(f1.generateRandom());

f1.js

function generateRandom() {
return Math.random();
} function sum(a, b) {
return a + b;
} export default {
generateRandom:generateRandom,
sum:sum
}

什么是Loader

Loader就是一个使你的资源经过一定transform变成新资源的东东(好吧 这个翻译很糟糕)

Loaders are transformations that are applied on a resource file of your app. They are functions (running in node.js) that take the source of a resource file as the parameter and return the new source.

url-loader

和file-loader类似 能够返回一个文件的路径

文件size 小于limit的 将返回文件的data-url

css-loader style-loader

style-loader是用于加载css文件的

css-loader是将css中的 import url 之类翻译为成require

http://stackoverflow.com/questions/25472908/is-the-webpack-style-loader-meant-to-load-all-css-or-just-application-specific

css还是建议使用html引入的方式

现代浏览器会先加载css并解析, 用html来引入css而不是bundle.js引入 页面加载更快

且对于base.css 浏览器可以缓存

html-loader

用于load模板html文件

比如var domTmp = require('./dom.tpl.html');

Webpack 从0开始的更多相关文章

  1. Webpack+vue2.0如何注册全局组件 (01)

    Part 1, 问题: webpack + vue2.0框架中,如何在入口js中注册组件? 就是在一个月以前,匆匆闯入vuejs这个社群,基本了解了vuejs的一些基础特性和语法.笔者兴致勃勃地开始想 ...

  2. webpack 4.0.0-beta.0 新特性介绍

    webpack 可以看做是模块打包机.它做的事情是:分析你的项目结构,找到JavaScript模块以及其它的一些浏览器不能直接运行的拓展语言(Scss,TypeScript等),并将其打包为合适的格式 ...

  3. 基于Vue + Vuex + Vue-router + Webpack 2.0打造微信界面

    一.项目简介 基于Vue + Vuex + Vue-router + Webpack 2.0打造微信界面,实现了微信聊天.搜索.点赞.通讯录(快速导航).个人中心.模拟对话.朋友圈.设置等功能. 二. ...

  4. webpack 4.0 相关

    Webpack 4.0发布了!! https://www.jianshu.com/p/3a13f1b37300 webpack详解 https://juejin.im/post/5aa3d2056fb ...

  5. Webpack 2.0 的文档

    Webpack 2.0 的文档 https://webpack.js.org/get-started/

  6. webpack 4.0 版本的简单使用

    webpack 4.0 学习指南 最近前端又要变天了,vue作者推出了vue-cli 3版本,并且里面使用了webpack 4. 但是webpack 3 和webpack 4 二者的使用方式完全不一样 ...

  7. webpack 3.1 升级webpack 4.0

    webpack 3.1 升级webpack 4.0 为了提升打包速度以及跟上主流技术步伐,前段时间把项目的webpack 升级到4.0版本以上 webpack 官网:https://webpack.j ...

  8. webpack 4.0尝鲜

    发布不久得webpack 4.0据说速度快了68% - 98%,然后还支持没配置文件,所以看起来很牛逼得样子 所以尝试一发 webpack和webpack-cli分离 现在执行webpack命令 必须 ...

  9. webpack 4.0 配置方法以及错误解决

    选取一个空目录来试验 全局安装webpack4.1之后 创建目录 mkdir webpacktest && cd webpacktes 初始化package.json npm init ...

  10. 走近webpack(0)--正文之前的故事

    在前端工作的过程中,只要你接触过vue,angular,react,gulp就一定知道webpack或者听说过或者使用过webpack,但是或许你对webpack的使用方法并不是十分了解,只是会用写好 ...

随机推荐

  1. JS判断表单内容是否更改过

    1,根据具体标签判断 function JudgesubmitForm() { var judjeWs = false; var judjeAt = false; var judjeWd = fals ...

  2. C++命名准则

    总则:命名用英语,单词简单,明了.意义明确.过长的单词可以使用省略.一般是去掉元音字母形成省略.如果有通用的缩写,应该采用通用的缩写. 1.函数命名 1.1:全局函数:采用限定词+动词(+名词的原则) ...

  3. VS2010 添加资源文件后,出现 “LNK1123: 转换到 COFF 期间失败: 文件无效或损坏”错误

    1>LINK : fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏 解决方法: 一.1.点击“项目”-->“属性”-->“清单工具” 2.‘输入 ...

  4. cx_Oracle模块详解

    1.安装cx_Oracle模块 1-1.环境准备: 1-1-1.oracle client最小安装 instantclient-sqlplus-linux.x64-11.2.0.4.0 instant ...

  5. Http Analyzer 数据抓包

    一.工具简介 这是一款实时分析 HTTP/HTTPS 数据流的工具.它可以实时捕捉HTTP/HTTPS 协议数据,可以显示许多信息(包括:文件头.内容.Cookie.查询字符窜.提交的数据.重定向的U ...

  6. [C#]6.0新特性浅谈

    原文:[C#]6.0新特性浅谈 C#6.0出来也有很长一段时间了,虽然新的特性和语法趋于稳定,但是对于大多数程序猿来说,想在工作中用上C#6.0估计还得等上不短的一段时间.所以现在再来聊一聊新版本带来 ...

  7. 倒计时 NAN 问题

    http://blog.csdn.net/lishangua/article/details/51506821

  8. 关于Char* ,CString ,WCHAR*之间的转换问题

    GDI+所有类的接口函数如果要传递字符串作为参数的话,似乎都用UNICODE串,即WCHAR*.我开始也被整得晕头转向,因为窗口编程所用往往是CString,用IO流读文件数据又得到char *.得益 ...

  9. ceph rpm foor rhel6

    ceph-0.86-0.el6.x86_64.rpm 09-Oct-2014 10:00 13M ceph-0.87-0.el6.x86_64.rpm 29-Oct-2014 13:38 13M ce ...

  10. AndroidUI 视图动画-自定义动画效果 (Animation)

    如果Android提供的四种动画 效果 和混合动画效果 不能够 满足需求的话,可以使用自定义动画效果 : 新建一个类CustomAnimation 使其继承自 android.view.animati ...