main.js 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. import Vue from 'vue';
  2. import axios from './router/axios';
  3. import VueAxios from 'vue-axios';
  4. import App from './App';
  5. import router from './router/router';
  6. import './permission'; // 权限
  7. import './error'; // 日志
  8. import './cache';//页面缓存
  9. import store from './store';
  10. import {loadStyle} from './util/util'
  11. import * as urls from '@/config/env';
  12. import Element from 'element-ui';
  13. import {
  14. iconfontUrl,
  15. iconfontVersion
  16. } from '@/config/env';
  17. import i18n from './lang'; // Internationalization
  18. import './styles/common.scss';
  19. import basicBlock from './components/basic-block/main';
  20. import basicContainer from './components/basic-container/main';
  21. import thirdRegister from './components/third-register/main';
  22. import avueUeditor from 'avue-plugin-ueditor';
  23. import website from '@/config/website';
  24. import crudCommon from '@/mixins/crud';
  25. import format from 'vue-text-format';//v-format
  26. // 注册全局crud驱动
  27. window.$crudCommon = crudCommon;
  28. // 加载Vue拓展
  29. Vue.use(router);
  30. Vue.use(VueAxios, axios);
  31. Vue.use(Element, {
  32. i18n: (key, value) => i18n.t(key, value)
  33. });
  34. Vue.use(window.AVUE, {
  35. size: 'small',
  36. tableSize: 'small',
  37. calcHeight: 65,
  38. i18n: (key, value) => i18n.t(key, value)
  39. });
  40. Vue.use(format);//v-format
  41. // 注册全局容器
  42. Vue.component('basicContainer', basicContainer);
  43. Vue.component('basicBlock', basicBlock);
  44. Vue.component('thirdRegister', thirdRegister);
  45. Vue.component('avueUeditor', avueUeditor);
  46. //自定义标题
  47. import containerTitle from './components/titleComponent/main.vue';
  48. Vue.component('containerTitle', containerTitle);
  49. // 加载相关url地址
  50. Object.keys(urls).forEach(key => {
  51. Vue.prototype[key] = urls[key];
  52. });
  53. // 加载website
  54. Vue.prototype.website = website;
  55. // 动态加载阿里云字体库
  56. iconfontVersion.forEach(ele => {
  57. loadStyle(iconfontUrl.replace('$key', ele));
  58. });
  59. Vue.config.productionTip = false;
  60. new Vue({
  61. router,
  62. store,
  63. i18n,
  64. render: h => h(App)
  65. }).$mount('#app');