vue如何搭建多页面多系统应用
网络编程 2021-07-04 15:03www.168986.cn编程入门
这篇文章主要为大家详细介绍了vue搭建多页面多系统应用的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文为大家分享了vue如何搭建多页面多系统应用,供大家参考,具体内容如下
一、多页面多系统应用
1、思路
使用Vue搭建多页应用。所有系统都在同一目录下。配置多入口多出口。每个系统之间可以链接。每个系统内依然采用Vue单页应用开发。
2、组件复用性
可以将所有的系统公共组件放到系统目录最外面,以达到组件复用。在系统内部依然将自己独立的组件封装,复用。这样可以最大限度的提高组件的复用性。
3、路由
每个系统单独进行路由配置
4、数据管理
每个系统数据仓库单独处理
5、目录结构
6、效果
在做Vue项目的时候,需要用对多个类似系统做一个集成。想过很多种方法,比如完全单页应用,分开独立应用,最终还是测试了一下多页面开发多系统。
准备工作
使用vue-cli搭建最基本的vue项目。
修改webpack配置
在这一步里我们需要改动的文件都在build文件下,分别是
- utils.js
- webpack.base.conf.js
- webpack.dev.conf.js
- webpack.prod.conf.js
- 我就按照顺序放出完整的文件内容,然后在做修改或添加的位置用注释符标注出来
utils.js
最添加如下代码
/ 这里是添加的部分 ---------------------------- 开始 / // glob是webpack安装时依赖的一个第三方模块,还模块允许你使用 等符号, 例如lib/.js就是获取lib文件夹下的所有js后缀名的文件 var glob = require('glob') // 页面模板 var HtmlWebpackPlugin = require('html-webpack-plugin') // 取得相应的页面路径,因为之前的配置,所以是src文件夹下的pages文件夹 var PAGE_PATH = path.resolve(__dirname, '../src/system') // 用于做相应的merge处理 var merge = require('webpack-merge') //多入口配置 // 通过glob模块读取pages文件夹下的所有对应文件夹下的js后缀文件,如果该文件存在 // 那么就作为入口处理 exports.entries = function() { var entryFiles = glob.sync(PAGE_PATH + '//.js') var map = {} entryFiles.forEach((filePath) => { var filename = filePath.substring(filePath.lastIndexOf('\/') + 1, filePath.lastIndexOf('.')) map[filename] = filePath }) return map } //多页面输出配置 // 与上面的多页面入口配置相同,读取pages文件夹下的对应的html后缀文件,然后放入数组中 exports.htmlPlugin = function() { let entryHtml = glob.sync(PAGE_PATH + '//.html') let arr = [] entryHtml.forEach((filePath) => { let filename = filePath.substring(filePath.lastIndexOf('\/') + 1, filePath.lastIndexOf('.')) let conf = { // 模板来源 template: filePath, // 文件名称 filename: filename + '.html', // 页面模板需要加对应的js脚本,如果不加这行则每个页面都会引入所有的js脚本 chunks: ['manifest', 'vendor', filename], inject: true } if (process.env.NODE_ENV === 'production') { conf = merge(conf, { minify: { removeComments: true, collapseWhitespace: true, removeAttributeQuotes: true }, chunksSortMode: 'dependency' }) } arr.push(new HtmlWebpackPlugin(conf)) }) return arr } / 这里是添加的部分 ---------------------------- 结束 /
webpack.base.conf.js
module.exports = { context: path.resolve(__dirname, '../'), / 修改部分 ---------------- 开始 / entry: utils.entries(), / 修改部分 ---------------- 结束 / output: { path: config.build.assetsRoot, filename: '[name].js', publicPath: process.env.NODE_ENV === 'production' ? config.build.assetsPublicPath : config.dev.assetsPublicPath } ... }
webpack.dev.conf.js
plugins: [ new webpack.DefinePlugin({ 'process.env': require('../config/dev.env') }), new webpack.HotModuleReplacementPlugin(), new webpack.NamedModulesPlugin(), // HMR shows correct file names in console on update. new webpack.NoEmitOnErrorsPlugin(), // https://github./ampedandwired/html-webpack-plugin / 注释这个区域的文件 ------------- 开始 / // new HtmlWebpackPlugin({ // filename: 'index.html', // template: 'index.html', // inject: true // }), / 注释这个区域的文件 ------------- 结束 / // copy custom static assets new CopyWebpackPlugin([{ from: path.resolve(__dirname, '../static'), to: config.dev.assetsSubDirectory, ignore: ['.'] }]) / 添加 .concat(utils.htmlPlugin()) ------------------ / ].concat(utils.htmlPlugin())
webpack.prod.conf.js
/ 注释这个区域的内容 ---------------------- 开始 / // new HtmlWebpackPlugin({ // filename: config.build.index, // template: 'index.html', // inject: true, // minify: { // removeComments: true, // collapseWhitespace: true, // removeAttributeQuotes: true // // more options: // // https://github./kangax/html-minifier#options-quick-reference // }, // // necessary to consistently work with multiple chunks via CommonsChunkPlugin // chunksSortMode: 'dependency' // }), / 注释这个区域的内容 ---------------------- 结束 /
添加
目录结构介绍
- src就是我所使用的工程文件了,assets,ponents,system分别是静态资源文件、组件文件、页面文件。
- 前两个就不多说,主要是页面文件里,我目前是按照项目的模块分的文件夹,你也可以按照你自己的需求调整。然后在每个模块里又有三个内容vue文件,js文件和html文件。这三个文件的作用就相当于做spa单页面应用时,根目录的index.html页面模板,src文件下的main.js和app.vue的功能。
- 原先,入口文件只有一个main.js,但现在由于是多页面,入口页面多了,我目前就是两个index和system2,之后如果打包,就会在dist文件下生成两个HTML文件index.html和system2.html(可以参考一下单页面应用时,打包只会生成一个index.html,区别在这里)。
注意的地方
配置js时候
import Vue from 'Vue' import cell from './cell.vue' / eslint-disable no-new / new Vue({ el: '#app', render: h => h(cell) })
页面跳转
可以写成 <a href='system2.html'></a>
打包后的资源路径
├── dist
│ ├── js
│ ├── css
│ ├── index.html
│ └── system2.html
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
上一篇:vue iview实现动态新增和删除
下一篇:vue2.0实现列表数据增加和删除
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程