entry.js 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. import Vue from 'vue';
  2. import entry from './app';
  3. import VueRouter from 'vue-router';
  4. import Element from 'main/index.js';
  5. import hljs from 'highlight.js';
  6. import routes from './route.config';
  7. import demoBlock from './components/demo-block';
  8. import MainFooter from './components/footer';
  9. import MainHeader from './components/header';
  10. import SideNav from './components/side-nav';
  11. import FooterNav from './components/footer-nav';
  12. import title from './i18n/title';
  13. import 'packages/theme-chalk/src/index.scss';
  14. import './demo-styles/index.scss';
  15. import './assets/styles/common.css';
  16. import './assets/styles/fonts/style.css';
  17. import icon from './icon.json';
  18. Vue.use(Element);
  19. Vue.use(VueRouter);
  20. Vue.component('demo-block', demoBlock);
  21. Vue.component('main-footer', MainFooter);
  22. Vue.component('main-header', MainHeader);
  23. Vue.component('side-nav', SideNav);
  24. Vue.component('footer-nav', FooterNav);
  25. Vue.prototype.$icon = icon; // Icon 列表页用
  26. const router = new VueRouter({
  27. mode: 'hash',
  28. base: __dirname,
  29. routes
  30. });
  31. router.afterEach(route => {
  32. // https://github.com/highlightjs/highlight.js/issues/909#issuecomment-131686186
  33. Vue.nextTick(() => {
  34. const blocks = document.querySelectorAll('pre code:not(.hljs)');
  35. Array.prototype.forEach.call(blocks, hljs.highlightBlock);
  36. });
  37. const data = title[route.meta.lang];
  38. for (let val in data) {
  39. if (new RegExp('^' + val, 'g').test(route.name)) {
  40. document.title = data[val];
  41. return;
  42. }
  43. }
  44. document.title = 'Element';
  45. ga('send', 'event', 'PageView', route.name);
  46. });
  47. new Vue({ // eslint-disable-line
  48. ...entry,
  49. router
  50. }).$mount('#app');