/iview-pro

基于 iview 的后台管理通用解决方案 😄

Primary LanguageVue

Iview Pro

Vue后台管理通用解决方案

使用

$ git clone https://github.com/xinpingJun/iview-pro.git
$ cd iview-pro
$ yarn install
$ yarn serve    # 访问 http://localhost:8080
$ yarn build    # 打包  

简介

  Iview Pro 基于Vue.js, 使用[iView],参考[ivew-admin], 使用vue-cli 3.0 脚手架搭建的Vue后台管理通用解决方案, 实现动态路由和权限验证, 封装axios, 新增常用页面, 加入ant-desgin 图标库。

项目结构

.
├── config   开发相关配置
├── dist     打包后文件
├── public   打包所需静态资源
└── src
    ├── api  接口文件
    ├── assets  静态文件(样式,图片,字体图标等。)
    ├── components  公共组件(可复用)
    ├── directive  自定义指令
    ├── libs  工具方法
    ├── router  路由配置
    ├── store  状态管理
    ├── vendors  公共库文件 (jaquery等)
    └── views 页面文件
    ├── App.vue 入口页面
    └── main.js 入口配置
├── eslintrc.js  Javascript静态检查工具
├── .gitignore  忽略文件配置
├── .postcssrc.js   css转化工具
├── babel.config.js  js代码转换配置文件
├── package.json   项目需要的模块
├── READEME.md   项目说明
├── vue.config.js  vue 配置文件
└── yran.lock   yarn 配置文件

后台管理开发备忘录

  • 动态路由 router.addRoutes(routes)
  • 权限控制 自定指令 directive
  • 登陆拦截 axios token/cookie
  • 开发环境/生产环境切换,配置文件
  • 表单详情页面,查询表格页面
  • 目录结构规范 组件使用index.js导出
  • 前期 mock 数据 , 后期添加服务端nodejs,koa2
  • 基于 Sortable.js 的 Vue 拖拽组件。 Vue.Draggable
  • Vue-Quill-Editor:基于Quill、适用于Vue2的富文本编辑器。
  • vddl:vue拖拽插件 http://hejx.space/vddl/#/zh-cn/guide/quick-start
  • jsplumb 流程图 https://jsplumbtoolkit.com

组件规范 (必须)

  • 组件名应该始终是多个单词的 命名:todo-item 导入/使用:TodoItem
  • 组件 data 必须为函数
  • Prop(传入的值) 定义应该尽量详细(默认值/对象/字符串/。。)
  • 总是用 key 配合 v-for 如:v-for="(item.index) in list" :key="index"
  • 永远不要把 v-if 和 v-for 同时用在同一个元素上。
  • 单文件组件中 :对于应用来说,顶级 App 组件和布局组件中的样式可以是全局的,但是其它所有组件都应该是有作用域的。
  • 在插件、混入等扩展中始终为自定义的私有属性使用 $_ 前缀。并附带一个命名空间以回避和其它作者的冲突 (比如 $yourPluginName)。

组件规范 (建议)

  • 把每个组件单独分成文件
  • 组件名称单词大写开头 (PascalCase)
  • 和父组件紧密耦合的子组件应该以父组件名作为前缀命名。 如:父,TodoList.vue 子,TodoListItem.vue TodoListItemButton.vue
  • 组件模板应该只包含简单的表达式,复杂的表达式则应该重构为计算属性或方法
  • 非空 HTML 特性值应该始终带引号 (单引号或双引号,选你 JS 里不用的那个) :style="{ width: sidebarWidth + 'px' }"
  • 指令缩写 (用 : 表示 v-bind: 和用 @ 表示 v-on:) 应该要么都用要么都不用。

组件/页面开发 文件结构命名范例

    ├── todo-list  组件
      ├── index.js  导出组件js
      ├── todo-list.vue  组件
      ├── todo-list.scss  样式文件
      ├── components   子组件
         ├── todo-list-item.vue
         ├── todo-list-item-button.vue

ClassName 命名规范

  • ClassName的命名应该尽量精短、明确,必须以字母开头命名,且全部字母为小写,单词之间统一使用下划线 " _ " 连接
  • id命名使用驼峰命名

scss 书写规范

兼容性

现代浏览器及 IE11。

页面展示

登陆页 首页

相关链接