webpack打包处理html、css、js、img、scss文件
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文件的更多相关文章
- vue2.0 在main.js引入scss文件报错
在vue2.0的main.js中引入scss文件报错 原因是在 在build文件夹下的webpack.base.conf.js的rules里面添加配置 { test: /\.scss$/, loade ...
- vue项目 安装和配置sass & main.js引入scss文件报错
通过npm 安装 cnpm install --save-dev sass-loader cnpm install --save-dev node-sass 在build文件夹下的webpack.ba ...
- webpack打包vue项目之后生成的dist文件该怎么启动运行
亲测,webpack打包vue项目之后生成的dist文件可以部署到 express 服务器上运行. 我的vue项目结构如下: 1. 进入该vue项目目录,打开git bash,执行:npm run b ...
- vue-cli || webpack 打包的时候css里面写的背景图片的路径出错问题
.bg width 100% position fixed left 0 top 0 height 100vh z-index -1 background url('~@/assets/imgs/bg ...
- 踩坑,vue项目中,main.js引入scss文件时报错
当我们在src目录下创建.scss文件,并在main.js中引用,运行时会报: ERROR Failed to compile with 1 errors 5:25:07 PMThis relativ ...
- webpack打包之有依赖js模块
一.入口文件main.js var isd = require('./depend.js'); if(isd.isDepend){ console.log('有依赖模块'); } else { con ...
- nginx 无法加载css/js图片等文件 404 not fund
刚配置Nginx反向代理,Nginx可能会出现无法加载css.js或者图片等文件,这里需要在配置文件*.conf里面加上如下配置项. location ~ .*\.(js|css|png|jpg)$ ...
- Nuget包含css\js等资源文件
<Project Sdk="Microsoft.NET.Sdk"> <PropertyGroup> <TargetFramework>netst ...
- Spring Boot thymeleaf模版支持,css,js等静态文件添加
Thymeleaf引入 Thymeleaf是一个Java模板引擎开发库,可以处理和生成HTML.XML.JavaScript.CSS和文本,在Web和非Web环境下都可以正常工作. 1.添加依赖包 & ...
- webpack快速入门——CSS进阶:SASS文件的打包和分离
1.安裝:因为sass-loader依赖于node-sass,所以需要先安装node-sass cnpm install node-sass --save-dev cnpm install sass- ...
随机推荐
- js一些重点知识总结(一)
1.javaScript与java的区别?(从它们的解释,运行等方面说) 第一,javascript是基于对象的,而java是面向对象,即java是一种真正的面向对象的语言,即使是开发简单的程序, ...
- WebService中的WSDL详解 及jmeter测试
首先简单讲解一下什么是wsdl. 一个WSDL文档通常包含8个重要的元素,即definitions.types.import.message.portType.operation.bin ...
- 香港服务器PING知识知多少?
香港服务器PING命令简介: PING命令是用来检查要到达的目标IP地址并记录结果,显示目标是否响应以及接收答复所需的时间.如果在传递到目标过程中有错误,ping 命令将显示错误消息. 我们在HOST ...
- vue.js移动端app实战2:首页
貌似有部分人要求写的更详细,这里多写一点vuel-cli基础的配置 什么是vue-cli? 官方的解释是:A simple CLI for scaffolding Vue.js projects, 简 ...
- GPUImage原理
GPUImage是一个开元的基于GPU的图片或视频的处理框架,其本身内置了多达120多种常见的滤镜效果,并且支持照相机和摄像机的实时滤镜,并且能够自定义图像滤镜. 美颜的基本概念 OpenGL ES: ...
- EXT系统中的信息查询
if (Ext.getCmp('rdPlaceLocation').checked) { choseRoad = false; var placeLocationWindow = Ext.getCmp ...
- 为什么要学习Java EE
Java EE学习之路 学习了Java SE,还只是完成“万里长征”的第一步. 接下来选择学习Java EE或是Java ME(或者你还想不断深入学习Java SE,只要你喜欢,你可以一直深入下去,就 ...
- 高性能MySQL之【第十五章 备份与恢复】学习记录
我们不打算包括的话题: 安全(访问备份,恢复数据的权限,文件是否需要加密) 备份存储在哪里,包括他们应该离源数据多远,以及如何将数据从源头移动到目的地 保留策略.审计 ...
- Oracle维护:每天的工作
Oracle维护:每天的工作 检查数据库状态 确认所有的INSTANCE状态以及listener状态正常,登陆到所有数据库或例程,检测ORACLE后台进程: $ ps –ef|grep ora $ l ...
- Oracle基础--体系
1. 连接到Oralce At the operating system prompt, enter the following command to start the SQLCommand Lin ...