时间:2021-05-26
本文主要介绍了vue 搭建后台系统模块化开发,分享给大家,具体如下:
效果
目录结构
├── README.md├── build│ ├── build.js│ ├── check-versions.js│ ├── logo.png│ ├── utils.js│ ├── vue-loader.conf.js│ ├── webpack.base.conf.js│ ├── webpack.dev.conf.js│ └── webpack.prod.conf.js├── config│ ├── dev.env.js│ ├── index.js│ └── prod.env.js├── index.html├── package-lock.json├── package.json├── src│ ├── App.vue│ ├── assets│ │ └── logo.png│ ├── components│ │ ├── HelloWorld.vue│ │ ├── header.vue│ │ ├── home.vue│ │ └── leftBanner.vue│ ├── main.js│ ├── router│ │ └── index.js│ └── views│ ├── active.vue│ ├── listOrder.vue│ ├── newOrder.vue│ ├── system.vue│ └── user.vue└── static实现方法:
第一步:使用vue-cli 脚手架初始化项目文件,具体步骤参考
vue.js 项目 环境搭建、运行、打包发布(常规版)
第二步:封装头部、侧边栏和公共容器组件
头部:用户信息等
侧边栏:用的elment-ui 的导航栏
公共容器:使用router-view 引入其他子页面,达到所有页面公用头部和侧边栏的效果
<template> <div> <el-container> <el-header> <temHeader></temHeader> </el-header> <el-container> <el-aside> <temLeftBanner></temLeftBanner> </el-aside> <el-main > <transition name="move" mode="out-in"> <router-view class="main-container"></router-view> </transition> </el-main> </el-container> </el-container> </div></template><script>import temHeader from './header.vue'import temLeftBanner from './leftBanner.vue'export default { data () { return { } }, components: { // 组件 temHeader, temLeftBanner }, computed: { // 计算 }, methods: { // 方法事件 }, mounted () { // 加载完成 }, created () { // 创建 }}</script><style lang='less'>.el-container{ height: 100vh;}.el-header, .el-footer { background-color: #B3C0D1; color: #333; text-align: center; line-height: 60px;}.el-aside { background-color: #D3DCE6; color: #333; text-align: center; line-height: 200px;}.el-main { background-color: #E9EEF3; color: #333; text-align: center;}.main-container{ max-width: 800px; margin: 0 auto;}body > .el-container { margin-bottom: 40px;}.el-container:nth-child(5) .el-aside,.el-container:nth-child(6) .el-aside { line-height: 260px;}.el-container:nth-child(7) .el-aside { line-height: 320px;}</style>第三步:内容页面
│ └── views│ ├── active.vue│ ├── listOrder.vue│ ├── newOrder.vue│ ├── system.vue│ └── user.vue第四步:路由
使用children来区分路由地址
import Vue from 'vue'import Router from 'vue-router'import home from '@/components/home'import listOrder from '@/views/listOrder'import newOrder from '@/views/newOrder'import active from '@/views/active'import system from '@/views/system'import user from '@/views/user'Vue.use(Router)export default new Router({ routes: [ { path: '/', redirect: '/listOrder' }, { path: '/', name: 'home', component: home, children: [ { path: '/listOrder', name: 'listOrder', component: listOrder }, { path: '/newOrder', name: 'newOrder', component: newOrder }, { path: '/active', name: 'active', component: active }, { path: '/system', name: 'system', component: system }, { path: '/user', name: 'user', component: user } ] }]})项目地址:https://github.com/Aimee1608/vueCommonModule
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一、前言开始模块化开发项目之后,一个很重要的问题就是页面见的跳转问题。关于模块化发开,可详见我的另一片文章Android模块化开发探索。正是由于将项目模块化拆分
Require.js与Sea.js的区别相同之处RequireJS和Sea.js都是模块加载器,倡导模块化开发理念,核心价值是让JavaScript的模块化开发
require模块化开发问题,正常自己写的模块是exports导出一个模块//模块化引入jquery不同和问题require引入jqueryswiper....
在前端模块化的时候,不仅仅是js需要进行模块化管理,html有时候也需要模块化管理。这里就介绍下如何通过requirejs,实现html代码的模块化开发。如何使
前言SeaJS是一个遵循CommonJS规范的JavaScript模块加载框架,可以实现JavaScript的模块化开发及加载机制。与jQuery等JavaSc