main.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  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. // weixin
  19. // import wx from '@/common/weixin-js-sdk.js'
  20. // weixin
  21. // Vue.use(wx)
  22. // i18n部分的配置
  23. // 引入语言包,注意路径
  24. import Chinese from '@/common/locales/zh.js';
  25. import English from '@/common/locales/en.js';
  26. // VueI18n
  27. import VueI18n from '@/common/vue-i18n.min.js'
  28. // VueI18n
  29. Vue.use(VueI18n)
  30. const i18n = new VueI18n({
  31. // 默认语言
  32. locale: 'zh',
  33. // 引入语言文件
  34. messages: {
  35. 'zh': Chinese,
  36. 'en': English,
  37. }
  38. })
  39. // 由于微信小程序的运行机制问题,需声明如下一行,H5和APP非必填
  40. Vue.prototype._i18n = i18n
  41. const app = new Vue({
  42. i18n,
  43. store,
  44. ...App
  45. })
  46. // http拦截器,将此部分放在new Vue()和app.$mount()之间,才能App.vue中正常使用
  47. import httpInterceptor from '@/common/http.interceptor.js'
  48. Vue.use(httpInterceptor, app)
  49. // http接口API抽离,免于写url或者一些固定的参数
  50. import httpApi from '@/common/http.api.js'
  51. Vue.use(httpApi, app)
  52. import config from "@/common/config.js"
  53. Vue.prototype.baseApi = config.baseApi;
  54. app.$mount()