main.js 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. import { createApp } from 'vue'
  2. import Cookies from 'js-cookie'
  3. import ElementPlus from 'element-plus'
  4. import locale from 'element-plus/lib/locale/lang/zh-cn' // 中文语言
  5. import '@/assets/styles/index.scss' // global css
  6. import App from './App'
  7. import store from './store'
  8. import router from './router'
  9. import directive from './directive' // directive
  10. // 注册指令
  11. import plugins from './plugins' // plugins
  12. import { download } from '@/utils/request'
  13. // svg图标
  14. import 'virtual:svg-icons-register'
  15. import SvgIcon from '@/components/SvgIcon'
  16. import elementIcons from '@/components/SvgIcon/svgicon'
  17. import './permission' // permission control
  18. import { useDict } from '@/utils/dict'
  19. import { parseTime, resetForm, addDateRange, handleTree, selectDictLabel } from '@/utils/ruoyi'
  20. // 分页组件
  21. import Pagination from '@/components/Pagination'
  22. // 自定义表格工具组件
  23. import RightToolbar from '@/components/RightToolbar'
  24. // 图片上传组件
  25. import ImageUpload from "@/components/ImageUpload"
  26. // 自定义树选择组件
  27. import TreeSelect from '@/components/TreeSelect'
  28. // 字典标签组件
  29. import DictTag from '@/components/DictTag'
  30. const app = createApp(App)
  31. // 全局方法挂载
  32. app.config.globalProperties.useDict = useDict
  33. app.config.globalProperties.download = download
  34. app.config.globalProperties.parseTime = parseTime
  35. app.config.globalProperties.resetForm = resetForm
  36. app.config.globalProperties.handleTree = handleTree
  37. app.config.globalProperties.addDateRange = addDateRange
  38. app.config.globalProperties.selectDictLabel = selectDictLabel
  39. // 全局组件挂载
  40. app.component('DictTag', DictTag)
  41. app.component('Pagination', Pagination)
  42. app.component('TreeSelect', TreeSelect)
  43. app.component('ImageUpload', ImageUpload)
  44. app.component('RightToolbar', RightToolbar)
  45. app.use(router)
  46. app.use(store)
  47. app.use(plugins)
  48. app.use(elementIcons)
  49. app.component('svg-icon', SvgIcon)
  50. directive(app)
  51. // 使用element-plus 并且设置全局的大小
  52. app.use(ElementPlus, {
  53. locale: locale,
  54. size: Cookies.get('size') || 'medium'
  55. })
  56. app.mount('#app')