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

本项目演示了使用 Vue、Axios 和 ElementUI 构建的单页应用程序,涉及Vue Router的使用,以及前端组件化开发。通过Vue组件展示了部门、员工信息的增删查改和分页操作,使用Vue-Router进行前端路由控制,实现页面跳转。项目中还引入了axios并配置了拦截器,处理请求和响应的通用操作。
摘要由CSDN通过智能技术生成
                   
                                                                                                   

说明:

本项目使用了 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';


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值