dotnetcore+vue+elementUI 前后端分离 三(前端篇)

墨蓝 2022-03-28 10:38 390阅读 0赞

说明:

本项目使用了 mysql employees数据库,使用了vue + axois + element UI 2.0 ,演示了 单页程序 架构 ,vue router 的使用,axois 使用,以及 element UI 控件的使用。通过这几种技术的组合,实现了对 employee 的增,删。查,改 ,分页操作,展示了在实际项目中,Vue 结合 elementUI 如何在前端项目中使用。

路由

说白了就是,页面的跳转如何控制。

当用户点击了部门信息就需要展示部门信息的;点击了员工信息就需要展示员工的总体信息,点击员工列表中明细信息就需要跳转到该员工的明细信息。如下图所示:

640?wx\_fmt=png&wxfrom=5&wx\_lazy=1

在传统的web程序中,跳转是由连接来控制的,不同的连接可以跳转到具体的页面,也可以在mvc 结构中 ,不同的路由地址,由controller返回不同的view。

在SPA单页程序中,路由一般是由专门的Router 来控制,而且Router是前端的组件,而不是由后端来控制的。

在本项目中,Vue 路由组件 使用的是 Vue-Router,部门,员工列表信息,员工明细信息 ,都是一个个 活生生 vue 组件,是前端组件,而不是一个页面。这种方式也是把web前端开发带入了组件化开发模式,

相对传统的web开发模式,进步可不是一点点。

项目结构:

640?wx\_fmt=png

核心组件介绍:

  • main

import Vue from ‘vue’

import ElementUI from ‘element-ui’

import ‘element-ui/lib/theme-chalk/index.css’

import App from ‘./App.vue’

import VueRouter from ‘vue-router’

import routerMap from ‘./router.js’

// 引入axios以及element ui中的loading和message组件

import axios from ‘axios’;

import { Loading, Message } from ‘element-ui’

Vue.use(VueRouter);

Vue.use(ElementUI);

Vue.prototype.$http = axios;

//axios 配置最好提出专门的页面

//axios.defaults.baseURL = “http://localhost:5001/api“;

axios.defaults.baseURL = “http://localhost/CMS.API/api“;

/**

* http配置

*/

// 引入axios以及element ui中的loading和message组件

// 超时时间

axios.defaults.timeout = 5000;

// http请求拦截器

var loadinginstace

axios.interceptors.request.use(config => {

// element ui Loading方法

console.log(config);

loadinginstace = Loading.service({ fullscreen: true })

return config

}, error => {

loadinginstace.close()

Message.error({

message: ‘加载超时’

})

return Promise.reject(error)

})

// http响应拦截器

axios.interceptors.response.use(data => {// 响应成功关闭loading

loadinginstace.close()

return data

}, error => {

loadinginstace.close()

Message.error({

message: ‘服务端发生错误’

})

return Promise.reject(error)

})

export default axios

const router = new VueRouter({ routes: routerMap })

const app = new Vue({

router

}).$mount(‘#app’);

axios 拦截器中添加的方法说明:

  1. 当http请求发出后,响应为返回前,前端页面弹出遮罩层,显示loading,避免用户在请求未响应前误操作。
  2. 当http请求发出后,发生异常后,前端提示用户,后台发生错误。
  3. 拦截一次处理了这两种通用的操作,其它地方再也不用以上两种操作。

    • router.js

/*!

//Router Map 文件

//hbb0b0@163.com

*/

import Help from ‘./components/help/Help.vue’;

import Feedback from ‘./components/feedback/Feedback.vue’;

import UserInfo from ‘./components/business/UserInfo.vue’;

import DepartmentList from ‘./components/business/DepartmentList.vue’;

import EmployeeList from ‘./components/business/Employee/EmployeeList.vue’;

import EmployeeDetail from ‘./components/business/Employee/EmployeeDetail.vue’;

import EmployeeAdd from ‘./components/business/Employee/EmployeeAdd.vue’;

import EmployeeEdit from ‘./components/business/Employee/EmployeeEdit.vue’;

import App from ‘./App.vue’

export default [{

path: ‘/index’,

component: App,

children: [

{

name: ‘部门信息’,

path: ‘departmentList’,

component: DepartmentList

},

{

name: ‘员工信息’,

path: ‘employee/list’,

component: EmployeeList

},

{

name: ‘帮助中心’,

path: ‘help’,

component: Help

},

{

name: ‘意见反馈’,

path: ‘feedback’,

component: Feedback

},

{

name:’员工详细信息’,

path:’employee/detail/:id’,

component:EmployeeDetail

},

{

name:’员工信息编辑’,

path:’employee/edit/:id’,

component:EmployeeEdit

},

{

name:’员工信息增加’,

path:’employee/add/‘,

component:EmployeeAdd

}

]

},

{

path: ‘*‘,

redirect: ‘/index/departmentList’

}

]

  • EmployeeList.vue

运行效果:

  • ElementUI table 排序

640?wx\_fmt=png

  • 分页

640?wx\_fmt=png

  • 设置分页大小

640?wx\_fmt=png

  • 提交验证功能

640?wx\_fmt=png

  • 异步验证功能

640?wx\_fmt=png

  • 多表格信息展示

640?wx\_fmt=png

  • 日期选择

640?wx\_fmt=png

  • 时间段选择

640?wx\_fmt=png

  • 确认提示

640?wx\_fmt=png

github 地址 https://github.com/hbb0b0/Hbb0b0.CMS/tree/master/hbb0b0.CMS.Portal

相关文章:

  • 浅谈开发模式及架构发展
  • dotnet core webapi +vue 搭建前后端完全分离web架构(一)
  • dotnetcore+vue+elementUI 前后端分离架 二(后端篇)

原文地址:http://www.cnblogs.com/hbb0b0/p/8399996.html


.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com

640?wx\_fmt=jpeg

再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow

发表评论

表情:
评论列表 (有 0 条评论,390人围观)

还没有评论,来说两句吧...

相关阅读

    相关 前后分离

    、前后端分离的好处 (1)彻底解放前端 (2)提高工作效率,分工更加明确。 (3)局部性能提升 (4)降低维护成本 2、前后端分离的概念 后台只需要提供API接口,

    相关 前后分离

    什么是前后端分离 在搞清楚前后端分离的概念之前,先来弄清楚什么是非前后端分离。 在传统的做法里面,比如servlet,tomcat都会在后台运行java代码,然后再后

    相关 前后分离

    转自:https://www.jianshu.com/p/21775989ec46 自从AJAX大行其道,前后端分离开发模式已是大势所趋,这里笔者针对对前后端分离开发模式谈谈