出国旅游手机不办理联通26元国际漫游办理 怎样知道自己的来电

以上是部分更新,你还可以查看
获取验证码
已有账号?
扫扫下载 App详解vue-cli + webpack 多页面实例配置优化方法 - 简书
详解vue-cli + webpack 多页面实例配置优化方法
vue+webpack是否有多页面
目前使用vue来做项目,估计大部分都是单页面(SPA)应用,一个轻型的 MVVM 框架,谁用了MVVM框架,就再也回不去JQ时代了,哈哈。
在手机端的项目,使用vue + vue-router是high到爆,不仅仅是我们开发的而言,最主要的用户体检也是开足马力,体检感杠杠的。
那问题来了,使用vue+webpack的单页面是爽到爆,那如果是多页面也能不能high到爆呢?那当然呀,必须的必,vue、webpack的忠粉(哈哈,好像这忠粉不关系到多页面的)。
在谷歌找vue 多页面,实例还是比较少,功夫不负有心人,在yaoyao1987那找到了,具体可以到这个,非常感谢yaoyao1987童鞋,今天要讲的内容是基于yaoyao1987童鞋的多页面实例上再优化的。
优化了点啥
demo、github地址
1、demo:2、github:
优化的内容
我们先来讲讲,具体我们优化了什么内容。
增加全局统一使用的模块Lib.js库,可能这里看不明白,不要紧,后面会讲到。
支持字体图标
增加干净的页面、组件的模板,复制即可以使用。
去掉多余的代码注释,坑了我的注释,别再坑人了
构建时,增加对css打包的支持
提取公共模块........
npm install
# 调试环境 serve with hot reload at http://localhost:8083/module/login.html
npm run dev
# 生产环境 build for production with minification
npm run build
本地默认访问端口为8083,需要更改的童鞋请到项目根目录文件config.js修改。
|---assets 资源
|---css.css
|---components 组件
|---Button.vue
|---module-head.vue
|---module各个页面模块
|---login.html
|---login.js
|---app.vue
|---welcome
欢迎页模块
|---welcome.html
|---welcome.js
|---app.vue
从目录结构上,各种组件、页面模块、资源等都按类新建了文件夹,方便我们储存文件。其实我们所有的文件,最主要都是放在module文件夹里,以文件夹名为html的名称。例如
|---login.html
|---login.js
|---app.vue
就是我们访问时的地址:
http://localhost:8083/module/login.html
这里一定要记住,在module里下级文件夹,一个文件夹就是一个html,js、vue template 都统一放在当前文件夹里,当然你也可以继续放其他的资源,例如css、图片等,webpack会打包到当前页面里。如果项目不需要这个页面了,可以直接把这个文件夹直接删除掉,干净项目,干活也开心。像以前我们传统开发项目,所有的图片都习惯放在images里,当项目有改动时,有些图片等资源用不上了,但还占着坑位,虽然现在的硬件容量大到惊人,但我们应该还是要养到一个良好的习惯。当前页面的开发在app.vue里,打开后你就会看到很熟悉的&template&、&script&、&style scoped&了。
全局统一公共模块
我们做多页面开发,那肯定会涉及到全局都能调用的公共库,或者是把别人封装的库也一起打包在全局公共模块里。
如果看过源码的童鞋,在*.vue页面里,我都统一import了一个文件
import Lib from 'assets/Lib.js'
这就是全局统一公共模块,我们先看看Lib.js里的代码
# 导入全局的css
import 'assets/css.css';
# 导入全局的站点配置文件
import C from 'assets/conf';
# 导入全局的共用事件
import M from 'assets/common';
var Rxports = {
module.exports = Rxports
在上方代码的M、C都是什么鬼,聪明的小伙伴就知道我想干嘛了,省写少事呗。例如我们现在想调用APP的名称,在.vue里可以这么写
import Lib from 'assets/Lib.js'
只需要在*.vue里导入import Lib from 'assets/Lib.js',就可以到处使用全局模块了。不再像传统的开发模式,需要一堆的&script&一个一个的来放到页面的底部。传统方式:
&script type='text/javascript' src='///sj/lib/zepto/zepto.min.js' charset='utf-8'&&/script&
&&/script&
&script type='text/javascript' src='///msui/sm/0.6.2/js/sm.min.js' charset='utf-8'&&/script&
&script type="text/javascript" src="http://res./open/js/jweixin-1.0.0.js"&&/script&
这里就是我想讲的关于优化的第一点提到的全局模块库。当然也有童鞋问呀,会不会每个页面都会把这些全局模块库都打包在当前页面,那JS文件体积大到惊人。哎呀,你当webpack是二货的呀,webpack会自动帮你处理好的,会把在*.vue里的import Lib from 'assets/Lib.js'的库自动提取出来,放到一个全局的JS文件里,这就是自动构造的神奇呀,省心省电,妈妈再也不用担心我做重复的工作了。
在Lib.js里,我们也看到有两个导入的JS文件,主要来做什么的呢?为了更好的在全局调用模块里,知道哪个模块的作用是什么,另外在写代码时更能快速查找到JS文件,我区分了配置文件和共用事件文件,即conf、common,下面说下具体的用途。
# 储存站点的配置,例如web的名称、LOGO地址等
import C from 'assets/conf';
# 导入全局的共用事件,例如在微信的JS SDK初始化,每个页面都要分享,都需要初始化的,一次调用,全局使用,棒!!
import M from 'assets/common';
当然,你也可以不像这样区分不同的JS文件,删除也没有影响的,具体也要看项目的需要而定,不能死读书。
另外,如果想要干净的页面模块模板,可以到根目录的tpl里复制module_tpl整个文件夹,然后粘贴到src/module目录下马上就可以进行开发了,开发之前记得在cmd里npm run dev跑一遍,新增页面都要重新dev一遍。
module我们就讲到这里,下面我们来讲讲组件的调用,最爱组件了。
组件的使用
组件(Component)是 vue.js 最强大的功能之一,当你发现使用组件可以减少造轮子里,你会深深的爱上它。我们的组件都是放在components目录下的,调用组件的方法也很简单。
import Button from 'components/Button';
然后记得在*.vue注册导入的组件,要不然会影响使用。
import Button from 'components/Button';
export default {
components: {
# 在这里注册组件,不注册组件的话,是无法使用的。
如果想要干净的组件模板,可以到根目录的tpl里找到components_tpl的Hello.vue文件,复制粘贴到components目录下马上就可以进行开发了。
在yaoyao1987童鞋里,是没有打包构造图标字体的代码逻辑,这也是我优化上去的一部分,建议使用iconfont图标( ,强大到无所不能,可以到iconfont下载自己想要的图标字体,记得是把文件放到\src\assets\font文件夹里。
webpack会自动打包的,无需理会,另外还有一点,iconfont提供的css文件,复制到\src\assets\css.css文件即可,要不然没有效果哈。在*.vue里使用调用就行了。
&i class="iconfont"&&#33&/i&
构建代码说明
那我们使用的是vue-cli的手脚架,用过vue+cli的朋友知道主要构建代码都放在根目录build下,vue多页面主要修改了这三个JS文件webpack.base.conf.js、webpack.dev.conf.js、webpack.prod.conf.js
# 【webpack.base.conf.js】主要是构建的全局设置,主要是增加了以下代码,已经增加在JS文件里,这里只是做一个补充说明,具体请看`build/webpack.base.conf.js`。
var entries = getEntry('./src/module/**/*.js'); // 获得入口js文件
var chunks = Object.keys(entries);
plugins: [
// 提取公共模块
new monsChunkPlugin({
name: 'vendors', // 公共模块的名称
chunks: chunks, // chunks是需要提取的模块
minChunks: chunks.length
// 配置提取出的样式文件
new ExtractTextPlugin('css/[name].css')
function getEntry(globPath) {
var entries = {},
basename, tmp,
glob.sync(globPath).forEach(function (entry) {
basename = path.basename(entry, path.extname(entry));
tmp = entry.split('/').splice(-3);
pathname = tmp.splice(0, 1) + '/' + // 正确输出js和html的路径
entries[pathname] =
这里还要做一个特别说明,我们每次更新资源文件,为了去缓存,都会给文件生成hash值,例如:
&script type='text/javascript' src='vendors.a3df9869.js' charset='utf-8'&&/script&
&script type='text/javascript' src='vendors.js?f3aaf25de220e214f84e' charset='utf-8'&&/script&
这两者都是为了去缓存,唯一的区别的生成的文件名不一样,有些项目,为了可以能出严重BUG时第一时间回滚,以文件名+hash的方式储存,每次生成都不会覆盖之前的代码,以方便查BUG或者回滚。另一种方式,就是以文件名+?hash的方式储存,每次都会覆盖之前生成的资源,方便在某些特殊项目使用。我在webpack.base.conf.js也已经注释说明了。
module.exports = {
entry: entries,
path: config.build.assetsRoot,
publicPath: config.build.assetsPublicPath,
/* ---- 生成的例子 vendors.a3df9869.js --- */
//filename: '[name].[hash].js'
/* ---- 生成的例子 vendors.js?f3aaf25de220e214f84e --- */
filename: '[name].js'
不知不觉时间又过去,啰嗦一堆堆的,每个项目需求都不一样,配置也会有许不同,也希望更多的朋友分享自己的代码和想法出来哈,也可以一起交流。有需要一起交流的可以加我的微信,amwhuang,记得备注技术交流哈。
首发博客地址:04:10:33 UTC
刚才打包正在做的项目,一个js文件有8M
04:55:36 UTC
哈哈哈。。。
05:07:34 UTC
压缩已经开启了吗?
06:38:54 UTC
即使压缩之后也减少不了多大体积~~最后估计还是有几M
08:00:29 UTC
我用了 React 以后 React 就很大, 现在能定位是什么原因吗?
08:07:38 UTC
一个页面依赖了那么多的js模块嘛?可以把公共的通过common plugin单独打成common.js
08:56:59 UTC
我现在也正在分离模块~~
12:52:05 UTC
github上面有webpack作者写的一个webpack打包分析的工具,可视化的看到webpack的状态,以及优化的一些建议,非常的不错。
01:05:42 UTC
webpack 可以分析依赖关系,把文件划分为几个 chunk,然后按需加载的啊。
03:21:31 UTC
HootSuite的前端做过有一个Webpack的分享,里面说了很多关于处理体积的技巧:/watch?v=w1dAb_Umt8o
09:24:01 UTC
06:23:46 UTC
打包后 8M, 这与任何打包软件及设置都关系不大吧,你用了多少 JS 代码库啊?? 自己算下,真要用这么多吗??
02:47:54 UTC
请问楼主解决了这个问题了吗?我查找了一下资料发现,可以用require.ensure方法进行codespliting
不过我是用react-router来进行路由的,这个方法似乎并不能用,然后看到github上面有人在讨论
请问有其他更好的方法吗?
05:11:58 UTC
可以尝试分离出common的js,然后一些不是马上用的js,动态require
15:25:30 UTC
可以试试,/QianmiOpen/react-async-router
08:28:57 UTC
给你个我最近使用的解决方法
15:11:44 UTC
react-router example 中有一个例子(react-router + webpack + require.ensure):
11:11:34 UTC
参考 中自定义公共模块提取部分,相关库可以打个包。另外就是打包设置。感觉不太可能会有8M的js哈。
03:51:06 UTC
推荐文章:
12:54:49 UTC
产品化打包一定要uglify并压缩,这个是webpack的插件
server开gzip
5M-》1.5M-》500KB

我要回帖

更多关于 联通26元国际漫游办理 的文章

 

随机推荐