main.js 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. import Vue from 'vue';
  2. import App from './App';
  3. Vue.config.productionTip = false;
  4. App.mpType = 'app';
  5. import VConsole from 'vconsole';
  6. //h5线上版调试台
  7. // const vConsole =new VConsole()
  8. // Vue.use(vConsole)
  9. // 此处为演示Vue.prototype使用,非uView的功能部分
  10. Vue.prototype.vuePrototype = '枣红';
  11. // 引入全局uView
  12. import uView from 'uview-ui';
  13. Vue.use(uView);
  14. // 此处为演示vuex使用,非uView的功能部分
  15. import store from '@/store';
  16. // 引入uView提供的对vuex的简写法文件
  17. let vuexStore = require('@/store/$u.mixin.js');
  18. Vue.mixin(vuexStore);
  19. // 引入uView对小程序分享的mixin封装
  20. let mpShare = require('uview-ui/libs/mixin/mpShare.js');
  21. Vue.mixin(mpShare);
  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. Vue.prototype.$hideLoading = function() { //异步操作结束,停止 loading
  50. this.$nextTick(() => {
  51. uni.hideLoading()
  52. })
  53. }
  54. Vue.prototype.$drawHonour = function(ctx, infoArr) { //绘制荣誉证书
  55. ctx.setTextAlign('center')
  56. ctx.setFontSize(infoArr[0][0])
  57. ctx.fillText(infoArr[0][1], infoArr[0][2], infoArr[0][3])
  58. ctx.setFontSize(infoArr[1][0])
  59. ctx.fillText(infoArr[1][1], infoArr[1][2], infoArr[1][3])
  60. ctx.setFontSize(infoArr[2][0])
  61. ctx.fillText(infoArr[2][1], infoArr[2][2], infoArr[2][3])
  62. ctx.draw()
  63. }
  64. // http接口API抽离,免于写url或者一些固定的参数
  65. import httpApi from '@/common/http.api.js';
  66. Vue.use(httpApi, app);
  67. app.$mount();