1.读万卷书,行万里路。

2.书山有路勤为径,学海无涯苦作舟。

技术段:

相信很多刚接触前端的小伙伴,对一些自动化工具会感觉无可下手。现在前端的发展的势头,势必和后台形成一个对立面,独挡一面。

这篇文章我就写一些关于webpack的东西,学的不深,后续深入学习再更新博客。

webpack是什么?为什么要使用webpack?其实做什么事都是一样的,一个东西的出现,必有它出现的意义。

webpack功能很多,当初接触webpack是因为在开发的过程中遇到一个问题,在版本迭代的时候会存在一个缓存的问题,就是当你更新

代码的时候,因为缓存的原因,你的新代码没能及时的上线,而功能就不会及时的呈现到用户面前。刚开始还不那么严重,到后面迭代

了很多个版本,这个问题一直存在,后面就有了关于webpack的学习。

这个我就只大概说一下整个流程,流程没有错,相信你会成功的把webpack的环境给安装成功。(网上有很多教程)

1.安装node.js。第一步肯定要装node.js这是webpack必须的开发环境,直接去node.js官网下载最新版本安装就可以了。

安装完可以在终端输入命令node -v检查安装的node.js的版本。

2.安装npm。这个也是必须安装的。npm是什么?建议你要去了解一下,这里推荐你一个纯技术网站,菜鸟教程。很适合新手。

在你开发项目的主目录打开终端,在终端输入 npm install --save-de 就可以安装了。你是不是在想为什么输入这个命令就可以了啊?

其实你不必奇怪,因为你安装了node.js,这些东西node.js里面的,你只是需要把它们下载到本地使用就可以了。不必惊讶。

3.后面就是安装很多很多的插件,记住这些插件也是在node.js里面下载的,我们只需要输入命令下载就可以了。

插件一:npm install --save-dev babel-core babel-loader babel-preset-es2015 babel-preset-react

插件二:npm install --save-dev style-loader css-loader

安装webpack:npm install --save-dev webpack-dev-server

在当前目录运行打包代码:npm run qzq  (运行的命令)

下面是一些文件的配置:

2、package.json配置内容
{
"name": "daka",
"version": "1.0.0",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"bdtt": "webpack --config webpack.bdtt.config.js",
"daka": "webpack --config webpack.daka.config.js",
"dakaSuccess": "webpack --config webpack.dakaSuccess.config.js",
"qzq": "webpack --config webpack.qzq.config.js"
},
"author": "zhang",
"license": "ISC",
"devDependencies": {
"autoprefixer": "^7.1.3",
"babel": "^6.23.0",
"babel-core": "^6.26.0",
"babel-loader": "^7.1.2",
"babel-preset-es2015": "^6.24.1",
"babel-preset-react": "^6.24.1",
"clean-webpack-plugin": "^0.1.16",
"css-loader": "^0.28.7",
"extract-text-webpack-plugin": "^3.0.0",
"file-loader": "^0.11.2",
"html-webpack-plugin": "^2.30.1",
"install": "^0.10.1",
"jquery": "^3.2.1",
"less": "^2.7.2",
"less-loader": "^4.0.5",
"npm": "^5.3.0",
"postcss-loader": "^2.0.6",
"style-loader": "^0.18.2",
"url-loader": "^0.5.9",
"webpack": "^3.5.5",
"webpack-dev-server": "^2.7.1"
},
"description": "wxy",
"dependencies": {
"webpack": "^3.5.5"
}
}
3、webpack.qzq.co3、webpack.qzq.co3、webpack.qzq.config.js内容
// 一个常见的`webpack`配置文件
const webpack = require('webpack');
var HtmlWebpackPlugin = require('html-webpack-plugin');
var CleanPlugin = require('clean-webpack-plugin');
var ExtractTextPlugin = require("extract-text-webpack-plugin");
var autoprefixer = require('autoprefixer');

module.exports = {
entry: {
'zmQzq':__dirname + "/require/qzq/zm_qzq.js",
'zmMine':__dirname + "/require/qzq/zm_mine.js",

},
output: {
path: __dirname + "/build/qzq",
filename: "[name].js"
},
devtool: 'none',
devServer: {
contentBase: "./",//本地服务器所加载的页面所在的目录
historyApiFallback: true,//不跳转
inline: true,
hot: true
},
module: {
rules: [
{
test: /(\.jsx|\.js)$/,
use: {
loader: "babel-loader"
},
exclude: /node_modules/
},
{
test: /\.css$/,
use: ExtractTextPlugin.extract({
fallback: "style-loader",
use: "css-loader"
})
},
{
test:/.(png)|(jpg)$/,
loader: "url-loader?limit=8192"
}
]
},
plugins: [
new CleanPlugin(['build'], {
root: '/Users/huizhang/web-git/apps/newproject/build/qzq',
// root: 'D:/web/apps/newproject/build',
verbose: true,
dry: false //false表示删除
/* 排除 exclude: ['shared.js']*/
}), //清空目录
new ExtractTextPlugin("[name].css"),
new HtmlWebpackPlugin({
filename: __dirname + '/resource/zm_insurance/zm_list.html', //这个路径要相对于output.path输出的JS设置 在JS的上一级就用 ../../
chunks: ['zmQzq'], //限定这个模板只引入index 和公用部分JS common.js
hash: true, // 为静态资源生成hash值 在引入资源地址后加上?hash值 实现不修改文件名加版本号功能
xhtml: true, // 需要符合xhtml的标准
inject: 'body',
template: __dirname + '/resource/zm_insurance/zm_list.ejs' //模板地址
}),
new HtmlWebpackPlugin({
filename: __dirname + '/resource/zm_insurance/zm_mine.html', //这个路径要相对于output.path输出的JS设置 在JS的上一级就用 ../../
chunks: ['zmMine'], //限定这个模板只引入index 和公用部分JS common.js
hash: true, // 为静态资源生成hash值 在引入资源地址后加上?hash值 实现不修改文件名加版本号功能
xhtml: true, // 需要符合xhtml的标准
inject: 'body',
template: __dirname + '/resource/zm_insurance/zm_mine.ejs' //模板地址
})
]
};

webpack自动化构建你的项目的更多相关文章

  1. Vue项目模板--和--webpack自动化构建工具的---项目打包压缩使用

    [首先安装node.js]: 1. 从node.js官网下载并安装node,安装过程很简单. 2. npm 版本需要大于 3.0,如果低于此版本需要升级它: # 查看版本 npm -v2.3.0 #升 ...

  2. D1.1.利用npm(webpack)构建基本reactJS项目

    前提: 已经安装nodejs和npm #全局安装webpack 自动构建化工具,职能管理项目:webpack-dev-server是开发工具,提供 Hot Module Replacement 功能# ...

  3. 用Docker运行Jenkins自动化构建.NET Core项目

    目标 当代码提交到GitHub后,自动生成构建项目并部署到服务器.接下来介绍一下如何在容器中运行Jenkins,并自动化构建GitHub上的项目,使用自动化构建来解放你的双手. 前置条件 一台已经安装 ...

  4. K8S+Jenkins自动化构建微服务项目(后续)

    因为之前写过基于K8S部署jenkins master/slave平台,在这个的基础上构建微服务到K8S集群中 Jenkins-slave构建微服务项目到K8S集群 1.微服务项目上传到git仓库 这 ...

  5. 亚信UED前端流程自动化构建工具

    亚信UED前端流程自动化构建工具 .wmd-input, .wmd-input:focus, #md-section-helper {font-size: 14px !important;line-h ...

  6. [Vue 牛刀小试]:第十七章 - 优化 Vue CLI 3 构建的前端项目模板(1)- 基础项目模板介绍

    一.前言 在上一章中,我们开始通过 Vue CLI 去搭建属于自己的前端 Vue 项目模板,就像我们 .NET 程序员在使用 asp.net core 时一样,我们更多的会在框架基础上按照自己的开发习 ...

  7. webpack前端构建工具学习总结(四)之自动化生成项目中的html页面

    接续上文:webpack前端构建工具学习总结(三)之webpack.config.js配置文件 插件的介绍文档:https://www.npmjs.com/package/html-webpack-p ...

  8. 前端项目自动化构建工具——Webpack入门教程

    参考资料:https://www.webpackjs.com/(中文文档)   https://www.webpackjs.com/(官方文档) 首先有必要说明一下,本文侧重讲解webpack基本配置 ...

  9. 前端开发自动化工作流工具,JavaScript自动化构建工具grunt、gulp、webpack介绍

    前端开发自动化工作流工具,JavaScript自动化构建工具grunt.gulp.webpack介绍 前端自动化,这样的一个名词听起来非常的有吸引力,向往力.当今时代,前端工程师需要维护的代码变得及为 ...

随机推荐

  1. LR脚本编写时的几个小技巧

    参数化空值 如上图所示,当参数化时某个值需要为空值(非空格),直接在参数化文件中空一行/格即可,虽然Parameter List界面上没有显示空的那一行,但并不影响取值. 手工日志跟踪 lr_set_ ...

  2. my.conf 修改编码

    mysql汉字乱码的原因 mysql默认的编码是Latin1是I-8859-1的别名,但Latin1是不支持汉字的,所以要将其改为UTF-8或GBK 1.关闭mysql服务器,这个很重要. 2.通过m ...

  3. 转 PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)

    PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)   通过curl_setopt()函数可以方便快捷的抓取网页(采集很方便),curl_setopt 是php的一个 ...

  4. Print之modile, level

    一般print打印的design都会引入module, level. xxxprint(module, level, arg,...)... 每个Module都可以有各自的bitmap,代表这个mod ...

  5. 当提交的表单类型为multipart/form-data时 后台的dopost则不能使用 setCharset来进行解码了 需要单独对字段使用 原始的new String(req.name("ISO-8859-1"),"utf-8")形式解码了

    当提交的表单类型为multipart/form-data时 后台的dopost则不能使用 setCharset来进行解码了 需要单独对字段使用 原始的new String(req.name(" ...

  6. Django 2.0 学习(05):Django Admin

    Django Admin 站点的管理者,而非访问者. 创建admin用户 首先,执行下面命令: python manage.py createsuperuser 其次,输入用户名和密码: Userna ...

  7. HTML5 不再支持哪些元素

    HTML5中已经不支持以下的元素,不建议在进行开发时再使用以下的元素. 1.acronym(建议abbr):定义首字母缩写 2.applet(建议object):定义applet 3.basefont ...

  8. NetScaler + Wireshark = A Perfect Combination!

    NetScaler + Wireshark = A Perfect Combination! https://www.citrix.com/blogs/2014/05/03/netscaler-wir ...

  9. All you need to know about sorting in Postgres

    按:之前看pg的执行计划,多次看到不同的排序方式,但不知何意.偶遇此篇讲解pg执行计划三种排序方式,备忘一下. Sorting Sorting is one of the most fundament ...

  10. group by多字段分组

    在平时的开发任务中我们经常会用到MYSQL的GROUP BY分组, 用来获取数据表中以分组字段为依据的统计数据.比如有一个学生选课表,表结构如下: Table: Subject_Selection S ...