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. Python学习记录----类型匹配(转)

    import types aaa = 0 print type(aaa) if type(aaa) is types.IntType: print "the type of aaa is i ...

  2. 控制反转(IoC)-解析与实现

    控制反转(Inversion of Control)缩写:IoC是面向对象编程中框架级别里的一个重要的概念, 可以说Spring框架的核心就是基于IoC原理的. 这个概念到底是什么呢? 这么讲吧,一个 ...

  3. Spring-mybatis没有了XXXmapper.java和Dao的实现类还有Service的实现类

    对于刚学过框架的同学可能知道,mybatis有两种主要的配置文件: SqlMapConfig.xml(mybatis全局配置文件,名称不固定,用来配置运行环境(数据源.事务) XXXmapper.xm ...

  4. Python爬虫初学(一)—— 爬取段子

    最近开始学Python的爬虫,是在这个博客跟着学习的,该博主用的是Python 2.7版本,而我使用的是3.5版本,很多不兼容的地方,不过没关系,自己改改就好了. 我们想针对网站的内容进行筛选,只获取 ...

  5. Spring框架集成mybatis框架的配置(笔记)

    <!-- 0.注解扫描 --><!-- 1.导入外部文件 --><!-- 2.数据源 --><!-- 3.session Factory -->< ...

  6. 安徽省2016“京胜杯”程序设计大赛_H_单身晚会

    单身晚会 Time Limit: 1000 MS Memory Limit: 65536 KB Total Submissions: 53 Accepted: 16 Description ​ZJ和Z ...

  7. 干货--Excel的表格数据的一般处理和常用python模块。

    写在前面: 本文章的主要目的在于: 介绍了python常用的Excel处理模块:xlwt,xlrd,xllutils,openpyxl,pywin32的使用和应用场景. 本文只针对于Excel表中常用 ...

  8. 2017年最重要的HTML5开发手册,传播正能量

    今天给大家推荐这个HTML5开发手册,希望能帮助正在学习web前端的人,鄙人也是刚学习前端没多久,借助于一点资讯平台能够结识更多前端大牛,这是我的HTML5进阶学习一点资讯群:250777811,里面 ...

  9. ubuntu修改grub,修改开机顺序,配置grub启动顺序

    方法一: 1.进入Ubuntu系统后打开终端 2.终端中输入以下命令 sudo gedit /boot/grub/grub.cfg 3.找到Windows的配置将其剪切到Ubuntu的前面 把下面 # ...

  10. 关于InnoDB存储引擎text和blob类型的优化

    我们在数据库优化的时候,看到一些表在设计上使用了text或者blob的字段,如果单表的存储空间达到了近上百G或者大几十G,这种情况再去改变和优化就非常难了 一.简介 为了清楚大字段对性能的影响,我们有 ...