pc_vue_admin/src/snowy.js

41 lines
1.6 KiB
JavaScript
Raw Normal View History

2024-07-23 03:24:17 +00:00
import * as antdvIcons from '@ant-design/icons-vue'
import config from './config'
import tool from './utils/tool'
import { hasPerm } from './utils/permission/index'
import errorHandler from './utils/errorHandler'
import customIcons from './assets/icons/index.js'
import 'highlight.js/styles/atom-one-dark.css'
import hljsCommon from 'highlight.js/lib/common'
import hljsVuePlugin from '@highlightjs/vue-plugin'
import STable from './components/Table/index.vue'
import Ellipsis from './components/Ellipsis/index.vue'
import DragModal from './components/DragModal/index.vue'
export default {
install(app) {
// 挂载全局对象
app.config.globalProperties.$CONFIG = config
app.config.globalProperties.$TOOL = tool
app.config.globalProperties.hasPerm = hasPerm
// 注册常用组件
app.component('STable', STable)
app.component('Ellipsis', Ellipsis)
app.component('DragModal', DragModal)
// 统一注册antdv图标
for (const icon in antdvIcons) {
app.component(icon, antdvIcons[icon])
}
// 统一注册自定义全局图标
app.use(customIcons)
// 注册代码高亮组件 博客https://blog.csdn.net/weixin_41897680/article/details/124925222
// 注意解决Vue使用highlight.js build打包发布后样式消失问题原因是webpack在打包的时候没有把未被使用的代码打包进去因此在此处引用一下看似无意义实则有用
hljsCommon.highlightAuto('<h1>Highlight.js has been registered successfully!</h1>').value
app.use(hljsVuePlugin)
// 全局代码错误捕捉
app.config.errorHandler = errorHandler
}
}