webpack --help 查看webpack命令
启动服务 npm run dev (先配置好服务)
进入对应文件夹并初始化npm
cd demo
npm init
安装webpack
npm install webpack --save-dev
默认package.json中scripts修改
"webpack": "webpack --config webpack.config.js --display-modules --progress --colors --display-reasons"
安装css loader 以便于支持loader
npm install css-loader style-loader --save-dev
引用文件中需要引入样式loader
require("style-loader!css-loader!./style.css");(style-loader必须放在css-loader前,否则要报错)
简单点通过命令行绑定loader
webpack hello.js hello.bundle.js --module-bind “css=style-loader!css-loader” 这里要用双引号
这句话每次打包都要绑定这个
--watch 自动打包 更改代码之后自动打包
--progress 看打包过程 --progress --display-modules 看打包模块
--progress --display-modules --display-reasons 看打包原因信息

入口实际用对象的形式 不同页面分别打包,chunkname和hashname是上线版本所需要的
webpack插件控制html页面引入的src 和打包后的js相同
npm install html-webpack-plugin --save-dev

title接收设定的参数写法
<title><%= htmlWebpackPlugin.options.title %></title>

var htmlWebpackPlugin=require("html-webpack-plugin");
module.exports={
entry:{
main:__dirname+"/src/script/main.js",
a:__dirname+"/src/script/a.js",
b:__dirname+"/src/script/b.js",
c:__dirname+"/src/script/c.js"
},
output:{
path:__dirname+"/dist",//html在dist目录下
filename:"js/[name].bundle.js", //js放在js目录下 用相对路径
//这里的name是entry中前边那个 main a
publicPath:'http://cdn.com',//线上地址

},
plugins:[
new htmlWebpackPlugin({
filename:'a.html',
template:'index.html',
//这里index 是根目录下的index.html
inject:false, //script标签嵌入位置
title:"this is A", // 传参
//chunks:["main","a"], //引入单独的chunks
excludeChunks:["b","c"] //排除的chunks
}),
new htmlWebpackPlugin({
filename:'b.html',
template:'index.html',
//这里index 是根目录下的index.html
inject:false, //script标签嵌入位置
title:"this is B", // 传参
//chunks:["b"],//引入单独的chunks
excludeChunks:["a","c"] //排除的chunks
}),
new htmlWebpackPlugin({
filename:'c.html',
template:'index.html',
//这里index 是根目录下的index.html
inject:false, //script标签嵌入位置
title:"this is C", // 传参
//chunks:["c"] , //引入单独的chunks
excludeChunks:["b","a"] //排除的chunks
}),
]
}

去掉公共路径 只要后边的路径
<%= compilation.assets[htmlWebpackPlugin.files.chunks.main.entry.substr(htmlWebpackPlugin.files.publicPath.length)].source() %>
单独引用某个js
<script src="<%= htmlWebpackPlugin.files.chunks.jq.entry %>"></script>
如果不包含main 则引入,这里是body标签有选择的引入。
<% for(var k in htmlWebpackPlugin.files.chunks) { %>
<% if(k !='main'){ %>
<script src="<%= htmlWebpackPlugin.files.chunks[k].entry %>"></script>
<% }%>
<% } %>
ERROR in Entry module not found: Error: Can't resolve 'babel-loader' in.........”
npm install babel-loader --save
Cannot find module 'babel-core'
npm link babel-core
babel 安装命令行代码
npm install babel-preset-env --save-dev
config.json文件中
module: {
loaders: [
{
test: /\.js$/,
loader: "babel-loader", //这里是babel-loader
"query": {
"presets": [ "env" ]
},
}
]
},
引入jq,
main.js中(或其他js)
import $ from './jquery-1.11.3';
window.$ = $;
window.jQuery = $;
export default $;
引入jq的文件
import $ from './main.js'

babel转化打包比较慢,速度优化
exclude include 相对路径和 绝对路径
exclude:__dirname+"/node_modules",//排除的范围(相对路径)
include:path.resolve(__dirname+"src"),//包含的范围
npm i style-loader css-loader --save-dev ======= npm install style-loader css-loader --save-dev

postcss-loader 增加厂商前缀
npm install postcss-import --save-dev
npm install autoprefixer --save-dev 安装postcss的一个插件
loaders:["style-loader","css-loader?importLoaders=1","postcss-loader"]
这里?importLoaders=1 是 在css文件中@import 其他css文件处理厂商前缀

安装less
npm i less-loader --save-dev
ERROR in Cannot find module 'less'
npm install --save-dev less
npm install --save-dev file-loader

打包顺序按js顺序输出
chunks:["main","jq","headerFun","rem"], //引入单独的chunks
//excludeChunks:[""] //排除的chunks
chunksSortMode: function (chunk1, chunk2) {
var chunks = ['main', 'jq', 'headerFun',"rem"];
var order1 = chunks.indexOf(chunk1.names[0]);
var order2 = chunks.indexOf(chunk2.names[0]);
return order1 - order2;
}
最顶部引入const autoprefixer = require('autoprefixer');
//postcss是js对css进行处理
new webpack.LoaderOptionsPlugin({
options: {
context: __dirname,
postcss: [
autoprefixer
]
}
})
处理html中的img标签的图片,安装npm i html-withimg-loader --save
npm install img-loader --save-dev

在 webpack 中引入图片需要依赖 url-loader 这个加载器。 npm install url-loader --save-dev
安装完file-loader就可以用一下代码处理css中的图片background:url()这种
{
test: /\.(jpe?g|png|gif|svg)$/,
loader: 'file-loader',
}
在顶部引入 var html = require('html-withimg-loader');
在htmlWebpackPlugin中加入这2行,

template: 'html-withimg-loader!' + path.resolve(__dirname, "live.html"),
filename: "live.html",

scss文件处理
//在项目下,运行下列命令行
npm install --save-dev sass-loader
//因为sass-loader依赖于node-sass,所以还要安装node-sass
npm install --save-dev node-sass

test:/\.scss$/,
loader:'style-loader!css-loader!sass-loader'

webpack打包处理html、css、js、img、scss文件的更多相关文章

  1. vue2.0 在main.js引入scss文件报错

    在vue2.0的main.js中引入scss文件报错 原因是在 在build文件夹下的webpack.base.conf.js的rules里面添加配置 { test: /\.scss$/, loade ...

  2. vue项目 安装和配置sass & main.js引入scss文件报错

    通过npm 安装 cnpm install --save-dev sass-loader cnpm install --save-dev node-sass 在build文件夹下的webpack.ba ...

  3. webpack打包vue项目之后生成的dist文件该怎么启动运行

    亲测,webpack打包vue项目之后生成的dist文件可以部署到 express 服务器上运行. 我的vue项目结构如下: 1. 进入该vue项目目录,打开git bash,执行:npm run b ...

  4. vue-cli || webpack 打包的时候css里面写的背景图片的路径出错问题

    .bg width 100% position fixed left 0 top 0 height 100vh z-index -1 background url('~@/assets/imgs/bg ...

  5. 踩坑,vue项目中,main.js引入scss文件时报错

    当我们在src目录下创建.scss文件,并在main.js中引用,运行时会报: ERROR Failed to compile with 1 errors 5:25:07 PMThis relativ ...

  6. webpack打包之有依赖js模块

    一.入口文件main.js var isd = require('./depend.js'); if(isd.isDepend){ console.log('有依赖模块'); } else { con ...

  7. nginx 无法加载css/js图片等文件 404 not fund

    刚配置Nginx反向代理,Nginx可能会出现无法加载css.js或者图片等文件,这里需要在配置文件*.conf里面加上如下配置项. location ~ .*\.(js|css|png|jpg)$ ...

  8. Nuget包含css\js等资源文件

    <Project Sdk="Microsoft.NET.Sdk"> <PropertyGroup> <TargetFramework>netst ...

  9. Spring Boot thymeleaf模版支持,css,js等静态文件添加

    Thymeleaf引入 Thymeleaf是一个Java模板引擎开发库,可以处理和生成HTML.XML.JavaScript.CSS和文本,在Web和非Web环境下都可以正常工作. 1.添加依赖包 & ...

  10. webpack快速入门——CSS进阶:SASS文件的打包和分离

    1.安裝:因为sass-loader依赖于node-sass,所以需要先安装node-sass cnpm install node-sass --save-dev cnpm install sass- ...

随机推荐

  1. PHP执行linux命令mkdir权限问题

    在linux系统中,root帐号执行php命令: mkdir('test', 0777); 结果文件的权限依然为: drwxr-xr-x 2 root root   Jul 27 19:30 test ...

  2. 超超超简单的bfs——POJ-3278

    Catch That Cow Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 89836   Accepted: 28175 ...

  3. (5)UIView常见属性

    此时打印的所有子控件会把使用自动布局的控件也打印出来,不准确,所以得去掉这两个选项,再进行打印 使用实例如下: viewWithTag的注意点,当有多个相同的Tag值时,它是先找到第一个Tag值,而不 ...

  4. Form表单中method=post/get两种数据传输的方式的区别

    Form提供了两种数据传输的方式——get和post.虽然它们都是数据的提交方式,但是在实际传输时确有很大的不同,并且可能会对数据产生严重的影响.虽然为了方便的得到变量值,Web容器已经屏蔽了二者的一 ...

  5. CentOS6 安装Sendmail + Dovecot + Squirrelmail

    本文记录在本地虚拟机CentOS6上搭建Sendmail + Dovecot + Squirrelmail 的Webmail环境的过程,仅仅是本地局域网的环境测试,不配置DNS, 也没有安全认证,Sq ...

  6. 创建 macvlan 网络 - 每天5分钟玩转 Docker 容器技术(55)

    上一节我们准备好了 macvlan 的实验环境,今天在 host1 和 host2 中创建 macvlan 网络 mac_net1: 注意:在 host2 中也要执行相同的命令. ① -d macvl ...

  7. .NET定位CPU使用率过高问题

    摘要: 当一个.net应用在生产环境CPU突然居高不下,如何快速准确的定位问题所在,并且对实时业务影响最小化?如何不抓Dump也不用live debug就可以知道你的应用在做什么?如何确认你的应用是由 ...

  8. Java入门——(5)Java API

      关键词:String类.StringBuffer类.System类.Math类.Random类.Date类.Calendar类.DateFormat类   API (Application Pro ...

  9. 使用 ESXi 虚拟化 Ryzen 1700

    最近开发的一个项目,需要多台机器支持,PC + 各种虚拟机,整得很乱,一怒之下,购买一台Ryzen 1700 + 32GB机器自行搭建服务器.经历两天时间,不停的踩坑,终于完成: Ryzen 1700 ...

  10. oracle-使用数据泵对不同用户和不同表空间的数据迁移

    oracle-使用数据泵对不同用户和不同表空间的数据迁移 ---------------------------------------------------2013/11/13 expdp和imp ...