create-app.js 2.0 KB
Newer Older
fxy060608's avatar
fxy060608 已提交
1 2
import 'uni-platform/runtime/index'

3 4 5
import Vue from 'vue'

import {
fxy060608's avatar
fxy060608 已提交
6 7
  initRefs,
  initHooks,
8
  initMocks
9 10 11 12 13
} from './util'

const hooks = [
  'onHide',
  'onError',
fxy060608's avatar
fxy060608 已提交
14 15
  'onPageNotFound',
  'onUniNViewMessage'
16 17
]

fxy060608's avatar
fxy060608 已提交
18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
function initVm (vm) {
  if (this.$vm) { // 百度竟然 onShow 在 onLaunch 之前?
    return
  }
  if (__PLATFORM__ === 'mp-weixin') {
    if (!wx.canIUse('nextTick')) { // 事实 上2.2.3 即可,简单使用 2.3.0 的 nextTick 判断
      console.error('当前微信基础库版本过低,请将 微信开发者工具-详情-项目设置-调试基础库版本 更换为`2.3.0`以上')
    }
  }

  this.$vm = vm

  this.$vm.$mp = {
    app: this
  }
}

35
export function createApp (vm) {
fxy060608's avatar
fxy060608 已提交
36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
  // 外部初始化时 Vue 还未初始化,放到 createApp 内部初始化 mixin
  Vue.mixin({
    beforeCreate () {
      if (!this.$options.mpType) {
        return
      }
      this.mpType = this.$options.mpType
      this.$mp = {
        data: {},
        [this.mpType]: this.$options.mpInstance
      }
      delete this.$options.mpType
      delete this.$options.mpInstance

      if (this.mpType !== 'app') {
fxy060608's avatar
fxy060608 已提交
51 52 53
        if (__PLATFORM__ !== 'mp-toutiao') { // 头条的 selectComponent 竟然是异步的
          initRefs(this)
        }
fxy060608's avatar
fxy060608 已提交
54 55
        initMocks(this)
      }
56 57 58 59
    },
    created () { // 处理 injections
      this.__init_injections(this)
      this.__init_provide(this)
fxy060608's avatar
fxy060608 已提交
60 61
    }
  })
62 63

  const appOptions = {
fxy060608's avatar
fxy060608 已提交
64
    onLaunch (args) {
fxy060608's avatar
fxy060608 已提交
65
      initVm.call(this, vm)
fxy060608's avatar
fxy060608 已提交
66

67 68 69 70
      this.$vm._isMounted = true
      this.$vm.__call_hook('mounted')

      this.$vm.__call_hook('onLaunch', args)
fxy060608's avatar
fxy060608 已提交
71 72 73 74 75
    },
    onShow (args) {
      initVm.call(this, vm)

      this.$vm.__call_hook('onShow', args)
76 77 78
    }
  }

fxy060608's avatar
fxy060608 已提交
79 80 81
  // 兼容旧版本 globalData
  appOptions.globalData = vm.$options.globalData || {}

82
  initHooks(appOptions, hooks) // 延迟执行,因为 App 的注册在 main.js 之前,可能导致生命周期内 Vue 原型上开发者注册的属性无法访问
83 84 85

  App(appOptions)

86
  return vm
87
}