首页 > 编程 > JavaScript > 正文

vue 搭建后台系统模块化开发详解

2019-11-19 11:39:35
字体:
来源:转载
供稿:网友

本文主要介绍了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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表