Vue3 globalProperties 的使用(代替 Vue.prototype.$xxx)

  • vue2 中绑定

    Vue.prototype.$dzm = 'dzm-test'
    
  • vue3 中绑定

    // 初始化相关
    import { createApp } from 'vue'
    import { nextTick } from "@vue/runtime-core"
    import App from './App.vue'
    import router from './router'
    import store from './store'
    
    // 创建对象
    const app = createApp(App)
    // 必须使用 nextTick,不然会有加载顺序问题,导致绑定失败
    nextTick(() => {
      // 代替 Vue.prototype.$xxx 绑定
      app.config.globalProperties.$dzm = 'dzm-test'
    })
    // 使用并挂载
    app.use(store).use(router).mount('#app')
    // 导出
    export default app
    
    <script>
    // js 中使用方式
    import { getCurrentInstance } from 'vue'
    export default {
      setup () {
        const { proxy } = getCurrentInstance()
        console.log(proxy.$dzm)
      }
    }
    </script>
    
    <!-- 模版中使用 -->
    <span>{{ $dzm }}</span>
    
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卡尔特斯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值