main.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. // The Vue build version to load with the `import` command
  2. // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
  3. import Vue from 'vue'
  4. import App from './App'
  5. import router from './router'
  6. import store from './config/config'
  7. import { Loading } from 'element-ui';
  8. // Message,
  9. import { myMessage } from './components/tools/message';
  10. import ajax from './common/axios.config'
  11. import qs from 'qs'
  12. import './common/player.css'
  13. import VideoPlayer from 'vue-video-player'
  14. const echarts = require('echarts');
  15. import 'video.js/dist/video-js.css' //videoJs的样式
  16. import 'vue-video-player/src/custom-theme.css' //vue-video-player的样式
  17. import VueCookies from 'vue-cookies'
  18. import hevueImgPreview from './components/tools/hevue-img-preview'
  19. import drag from './components/directive/el-drag-dialog';
  20. import VueAudio from 'vue-audio-better'
  21. Vue.use(VideoPlayer).use(VueAudio).use(VueCookies).use(hevueImgPreview, {
  22. clickMaskCLose: true
  23. }).use(drag)
  24. Vue.prototype.$echarts = echarts
  25. Vue.prototype.$equipment=function(){
  26. let flag = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i);
  27. return flag;
  28. }
  29. Vue.config.productionTip = false
  30. Vue.prototype.$store = store; // 将store实例挂在vue原型上
  31. Vue.prototype.ajax = ajax
  32. // Vue.prototype.$message = Message
  33. Vue.prototype.$message = myMessage
  34. Vue.prototype.$loading = Loading
  35. Vue.prototype.openLoading = function(target) {
  36. const loading = this.$loading.service({ // 声明一个loading对象
  37. lock: true, // 是否锁屏
  38. background: 'rgba(255, 255, 255, 0.7)', // 背景颜色
  39. target: target ? target : document.body, // 需要遮罩的区域
  40. body: true,
  41. })
  42. return loading;
  43. }
  44. Vue.prototype.$qs = qs
  45. /* eslint-disable no-new */
  46. new Vue({
  47. el: '#app',
  48. router,
  49. components: { App },
  50. template: '<App/>'
  51. })
  52. VueCookies.config('30d')
  53. router.beforeEach((to, from, next) => {
  54. if (to.meta.title) {
  55. document.title = to.meta.title
  56. }
  57. const requireAuth = to.meta.requireAuth
  58. // 判断该路由是否需要登录权限
  59. if (requireAuth) {
  60. var isLogin = VueCookies.get('tlogin')
  61. if (isLogin == "1") {
  62. var userinfo = VueCookies.get('studentInfo')
  63. store.commit("update", ["isLogin", true]);
  64. // var info = JSON.parse(window.sessionStorage.getItem("userInfo"))
  65. store.commit("update", ["userInfo", userinfo]);
  66. store.state.luyou = store.state.luyou + 1
  67. store.commit("update", ["luyou", store.state.luyou]);
  68. next()
  69. } else {
  70. const loading = Loading.service({
  71. background: "rgba(255, 255, 255)",
  72. target: document.querySelector("body"),
  73. });
  74. store.commit("update", ["isLogin", false]);
  75. Message({
  76. message: '未登录,请登录',
  77. type: 'warning'
  78. });
  79. setTimeout(() => {
  80. loading.close();
  81. next('/login')
  82. }, 2000);
  83. }
  84. } else {
  85. next() // 确保一定要有next()被调用
  86. }
  87. })