main.js 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. import 'babel-polyfill'
  2. import 'classlist-polyfill'
  3. import Vue from 'vue'
  4. import axios from './router/axios'
  5. import VueAxios from 'vue-axios'
  6. import App from './App'
  7. import ElementUI from 'element-ui'
  8. import 'element-ui/lib/theme-chalk/index.css'
  9. import Avue from '@smallwei/avue'
  10. import '@smallwei/avue/lib/index.css'
  11. import AvueFormDesign from '@sscfaith/avue-form-design'
  12. import './permission' // 权限
  13. import './error' // 日志
  14. import router from './router/router'
  15. import store from './store'
  16. import {loadStyle} from './util/util'
  17. import * as urls from '@/config/env'
  18. import {
  19. iconfontUrl,
  20. iconfontVersion
  21. } from '@/config/env'
  22. import * as filters from './filters' // 全局filter
  23. import './styles/common.scss'
  24. import basicContainer from './components/basic-container/main'
  25. import * as echarts from 'echarts';
  26. import 'xe-utils'
  27. import VXETable from 'vxe-table'
  28. import 'vxe-table/lib/index.css'
  29. Vue.prototype.$echarts = echarts
  30. window.axios = axios
  31. Vue.use(VueAxios, axios)
  32. import dataV from '@jiaminghi/data-view'
  33. Vue.use(dataV)
  34. Vue.use(VXETable)
  35. Vue.use(ElementUI, {
  36. size: 'small',
  37. menuType: 'text'
  38. })
  39. Vue.use(Avue, {
  40. size: 'small',
  41. menuType: 'text'
  42. })
  43. Vue.use(router)
  44. Vue.use(AvueFormDesign);
  45. // 注册全局容器
  46. Vue.component('basicContainer', basicContainer)
  47. // 加载相关url地址
  48. Object.keys(urls).forEach(key => {
  49. Vue.prototype[key] = urls[key]
  50. })
  51. //加载过滤器
  52. Object.keys(filters).forEach(key => {
  53. Vue.filter(key, filters[key])
  54. })
  55. // 动态加载阿里云字体库
  56. iconfontVersion.forEach(ele => {
  57. console.log(iconfontUrl.replace('$key', ele))
  58. loadStyle(iconfontUrl.replace('$key', ele))
  59. })
  60. Vue.config.productionTip = false
  61. new Vue({
  62. router,
  63. store,
  64. render: h => h(App)
  65. }).$mount('#app')