main.js 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. import Vue from 'vue';
  2. import App from './App';
  3. Vue.config.productionTip = false;
  4. App.mpType = 'app';
  5. // 此处为演示Vue.prototype使用,非uView的功能部分
  6. Vue.prototype.vuePrototype = '枣红';
  7. // 引入全局uView
  8. import uView from 'uview-ui';
  9. Vue.use(uView);
  10. // 此处为演示vuex使用,非uView的功能部分
  11. import store from '@/store';
  12. // 引入uView提供的对vuex的简写法文件
  13. let vuexStore = require('@/store/$u.mixin.js');
  14. Vue.mixin(vuexStore);
  15. // 引入uView对小程序分享的mixin封装
  16. let mpShare = require('uview-ui/libs/mixin/mpShare.js');
  17. Vue.mixin(mpShare);
  18. // i18n部分的配置
  19. // 引入语言包,注意路径
  20. import Chinese from '@/common/locales/zh.js';
  21. import English from '@/common/locales/en.js';
  22. // VueI18n
  23. import VueI18n from '@/common/vue-i18n.min.js';
  24. import tabBar from 'components/tabbar.vue'
  25. Vue.component('tab-bar', tabBar) //挂载
  26. // VueI18n
  27. Vue.use(VueI18n);
  28. const i18n = new VueI18n({
  29. // 默认语言
  30. locale: 'zh',
  31. // 引入语言文件
  32. messages: {
  33. 'zh': Chinese,
  34. 'en': English,
  35. }
  36. });
  37. // 由于微信小程序的运行机制问题,需声明如下一行,H5和APP非必填
  38. Vue.prototype._i18n = i18n;
  39. const app = new Vue({
  40. i18n,
  41. store,
  42. ...App
  43. });
  44. // http拦截器,将此部分放在new Vue()和app.$mount()之间,才能App.vue中正常使用
  45. import httpInterceptor from '@/common/http.interceptor.js';
  46. Vue.use(httpInterceptor, app);
  47. //全局方法判断权限
  48. import $p from './common/public.js'
  49. Vue.prototype.$transformAuth = $p.transformAuth
  50. // http接口API抽离,免于写url或者一些固定的参数
  51. import httpApi from '@/common/http.api.js';
  52. Vue.use(httpApi, app);
  53. import dropdown from './components/dt-dropdown/dt-dropdown.vue'
  54. Vue.component('dropdown', dropdown)
  55. app.$mount();