记webpack下进行普通模块化开发基础配置(自动打包生成html、多入口多页面)
写本记时(2018-06-25)的各版本
"webpack-dev-server": "^3.1.4" //当天安装
html-webpack-plugin 的配置
首先装好html-webpack-plugin,在webpack.config.js 配置2个入口文件,和滤镜中2个出口文件(即生成2个页面)
注意入口配置的键名前面加目录,打包之后js会按路径存放 或者在出口的filename右边加个目录也可以
const path = require('path')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const MiniCssExtractPlugin = require("mini-css-extract-plugin")
//配置项
module.exports = {
entry : {
'index' : __dirname + '/src/index.js',
'main' : __dirname + '/src/main.js',
'jqueryv183min' :__dirname + '/src/jqueryv183min.js'
},
output:{
path: __dirname + '/dist',
filename:'js/[name].js',
publicPath:'/',
},
devServer:{
contentBase:path.resolve(__dirname,'./src'),
host:'localhost',
compress:false,
port:8100,
hot:false
},
module:{
rules:[
{
test: /.js$/,
loader: 'babel-loader?presets=es2015',
},
{
test: /\.(htm|html)$/i,
loader: 'html-withimg-loader'
},
{
test:/\.(jpg|png|gif|svg)$/,
//小于1024的图片都用base64的方式加载
loader: 'url-loader',
options: {
limit: 1024,
outputPath:'images/'
}
},
{
test: /\.css$/,
loader:[MiniCssExtractPlugin.loader,'css-loader']
}
]
},
plugins:[
new HtmlWebpackPlugin({
template: __dirname + "/src/index.html",
filename:'index.html',
title:'哈哈',
chunks:['jqueryv183min','index'],
//按上面的chunks数组顺序来插入js文件
chunksSortMode: 'manual',
minify:true,
hash:true //这样资源扩展名后面会增加hash值
}),
new HtmlWebpackPlugin({
template: __dirname + "/src/main.html",
filename:'main.html',
title:'嘿嘿',
chunks:['main'],
chunksSortMode: 'manual'
}),
new MiniCssExtractPlugin({
filename: "css/[name].css",
chunkFilename: "[id].css"
})
]
}
打包命令:webpack
webapck-dev-server配置:
devServer:{
contentBase:path.resolve(__dirname,'./src'),
host:'localhost',
compress:false,
port:8100,
hot:false
},
关于webpack 4.x以上的开发模式(快速自动刷新)
在package.json里面script中加入一条:
"dev": "webpack-dev-server --mode development",
然后运行cnpm run dev
html中显示图片,打包到文件夹
首先安装file-loader、url-loader、(url-loader内置了file-loader) html-withimg-loader(这个好像不能安装在dev下?)
在module:{rules[]}中加入2个规则:
{
test: /\.(htm|html)$/i,
loader: 'html-withimg-loader'
},
{
test:/\.(jpg|png|gif|svg)$/,
//小于1024的图片都用base64的方式加载
loader: 'url-loader',
options: {
limit: 1024,
outputPath:'images/'
}
}
以模块方式加载css文件,抽离为css文件独立打包
旧的是用extract-text-webpack-plugin,而4.0以上已经废弃,使用mini-css-extract-plugin
首先安装 cnpm i style-loader css-loader mini-css-extract-plugin --save-dev
要在入口文件中引入css文件(只能以这个方式引入css,并且html-webpack-plugin会自动加载?):import idxcss from './css/base.css'
规则中添加
{
test: /\.css$/,
loader:[MiniCssExtractPlugin.loader,'css-loader']
}
滤镜中添加
new MiniCssExtractPlugin({
filename: "css/[name].[chunkhash:8].css",
chunkFilename: "[id].css"
})
这样css中的图片也会被打包到css目录
清空打包目录clean-webpack-plugin
安装插件 clean-webpack-plugin
const cleanWebpackPlugin = require('clean-webpack-plugin')
new cleanWebpackPlugin(
['dist/*.*','dist/css/*.*','dist/js/*.*'], //匹配删除的文件
{
root: __dirname, //根目录
verbose: true, //开启在控制台输出信息
dry: false //启用删除文件
}
)
//注,上面要匹配文件的方式来写,不可直接写一个dist目录
//网上很多不负责的文章,就直接扔一个dist进去
复制静态文件
当有一些不参与打包的文件时,使用此插件:copy-webpack-plugin
const CopyWebpackPlugin=require('copy-webpack-plugin');
new CopyWebpackPlugin([{
from: __dirname + '/src/static',
to: __dirname + '/dist/static'
}])
启用静态http服务器查看打包效果
为了统一各种静态资源的路径,在出口配置中加入publicPathc :'/' ,所有相对路径资源都会转换成根目录路径
这时,全局安装cnpm i -g http-server,进入打包目录 执行 http-server ,即可启动静态http服务器
记webpack下进行普通模块化开发基础配置(自动打包生成html、多入口多页面)的更多相关文章
- webpack前置知识1(模块化开发)
webpack前置知识1(模块化开发) 新建 模板 小书匠 在开始对模块化开发进行讲解之前,我们需要有这么一个认识,即 在没有过多第三方干扰时,成本低收益高的事物更容易获得推广和信赖. 模块化开发就 ...
- 初学seaJs模块化开发,利用grunt打包,减少http请求
原文地址:初学seaJs模块化开发,利用grunt打包,减少http请求 未压缩合并的演示地址:demo2 学习seaJs的模块化开发,适合对seajs基础有所了解的同学看,目录结构 js — —di ...
- Andorid Studio 模块化开发相关配置
Andorid Studio 模块化开发相关配置 下面以宿主APP模块和Uer_Module模块为例: 第一步:在项目根目录gradle.properties配置文件中添加如下代码 isNeedUse ...
- webpack配置自动打包重新运行npm run dev出现报错
webpack配置自动打包重新运行npm run dev出现报错 运行npm run dev出现如下报错 Listening at http://localhost:8080(node:2328) U ...
- webpack初体验之模块化开发
写在前面的话 上次写过一篇关于webpack入门的博客,当时只是说借助node来完成开发,并用webpack打包以让浏览器识别.其实其主要思想就是实现前端模块化开发. 众所周知,历史上,JavaScr ...
- webpack学习2.1 模块化开发(JS模块化&CSS模块化)
一.JS模块化 命名空间,COMMONJS,AMD/CMD/UMD,ES6 module 1.什么是命名空间 库名.类别名.方法名 弊端:在命名空间重复生命,要记住完整的路径名(而且很长) var N ...
- 01-flask电商项目开发基础配置
本项目前端采用vue-cli的脚手架,后端采用Flask的Web框架.项目通过完成用户管理.权限管理.商品管理.订单管理.统计管理等功能,综合了前后端的知识,希望使大家都能受益. 1.使用到的技术如下 ...
- webpack中Entry与Output的基础配置
entry顾名思义,就是打包的入口文件 module.exports = { // 这个文件要做打包,从哪一个文件开始打包 entry: './src/index.js', // 打包文件要放到哪里去 ...
- Eclipse下Android的NDK开发环境配置
编辑2016年7月26日——增加了下载网址,修改了一些错误. 摸索了一周,走了很多弯路,磕磕绊绊,总算是弄好了NDK的开发环境,在这里总结一下吧. 一.Android NDK开发环境 首先下载安装JR ...
随机推荐
- M1阶段事后总结
设想和目标 1. 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述?我们组要爬取网上的内容供下一组使用,定义的不太清楚,因为用户只有下一个团队所以没有进行详细的需求分析 ...
- Docker打DB2 9.7镜像采坑相关
概况:以centos:7.2.1511镜像为基础镜像,使用docker commit方式进行构建 步骤: 运行centos7.2.1511镜像(以特权模式运行,后续内核参数修改必需参数) dock ...
- 代理 ip
利用 VPN 技术通过一台服务器将自己的电脑冒名借用这个服务器的ip ,这台服务器的 ip 即为代理 ip,被冒名ip的服务器即为 代理服务器.我猜的. 实验 这次使用的是 芝麻软件 代理ip软件,其 ...
- Daily Scrum - 12/04
Meeting Minutes 与Qiufeng, Bojie, Zhongqiu, Ran, Travis一起讨论. 确定了最后的UI及Feature. 开始Code Review, 以及有计划的M ...
- do
http://www.cnblogs.com/xdp-gacl/p/3791993.html http://blog.sina.com.cn/s/blog_95c8f1ac010198j2.html
- react-router JS 控制路由跳转(转载)
Link组件用于正常的用户点击跳转,但是有时还需要表单跳转.点击按钮跳转等操作.这些情况怎么跟React Router对接呢? 下面是一个表单. <form onSubmit={this.han ...
- 贝云cms内容管理系统(thinkphp5.0开源cms管理系统)
byCms包含文章,图片,下载,视频模型,基于thinkphp5.0.9,可无缝升级至thinkphp.1.0,是一套简单,易用的内容管理系统,旨在帮助开发者节约web应用后台开发时间和精力,以最快的 ...
- laravel 登录后跳转原来浏览的页面
方法 1.修改一下文件/vendor/laravel/framework/src/Illuminate/Foundation/Auth/RedirectsUsers.php 修改内容如下: 没有的加入 ...
- Torch,Tensorflow使用: Ubuntu14.04(x64)+ CUDA8.0 安装 Torch和Tensorflow
系统配置: Ubuntu14.04(x64) CUDA8.0 cudnn-8.0-linux-x64-v5.1.tgz(Tensorflow依赖) Anaconda 1. Torch安装 Torch是 ...
- Vue---从后台获取数据vue-resource的使用方法
作为前端人员,在开发过程中,我们大多数情况都需要从后台请求数据,那么在vue中怎样从后台获取数据呢?接下来,我简单介绍一下vue-resource的使用方法,希望对大家有帮助. 一.下载vue-res ...