91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue3中的getCurrentInstance如何使用

發布時間:2023-05-16 16:41:35 來源:億速云 閱讀:171 作者:zzz 欄目:編程語言

這篇“vue3中的getCurrentInstance如何使用”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“vue3中的getCurrentInstance如何使用”文章吧。

父組件中:

1.setup語法糖中導入子組件

2.在子組件標簽上綁定ref值

3.setup內部從vue中按需導出 getCurrentInstance 方法

4.調用getCurrentInstance方法導出proxy

5.通過proxy.$refs.子組件ref名.子組件內屬性/方法 實現調用

<template>
  <!-- 父組件 -->
  <div>
    <!-- 子組件 -->
    <Child ref="child" />
    <button @click="changeChildren">子組件count+1</button>
  </div>
</template>
 
<script setup lang="ts" name="Father">
import { getCurrentInstance, ComponetInternalInstance,ref } from "vue";
import Child from "./zi.vue";
const child = ref(null)
 // as ComponetInternalInstance表示類型斷言,ts時使用。否則報錯,proxy為null
const { proxy } = getCurrentInstance() as ComponetInternalInstance;
function changeChildren() {
  proxy.$refs.child.count += 1;
  //也可以使用ref數據.value的形式調用:
  //child.value.count += 1
  console.log(child.value.name)
}
</script>
 
<style scoped></style>

main.js

import api from "./utils/api.js"
import StringUtil from "./utils/StringUtil.js"

app.config.globalProperties.api = api;
app.config.globalProperties.StringUtil = StringUtil;
import {getCurrentInstance } from 'vue';

const { proxy } = getCurrentInstance();

console.log(proxy.api);
console.log(proxy.StringUtil.isBlank('1'));

方式一、通過 getCurrentInstance 方法獲取當前組件實例,從而獲取 route 和 router

Html

<template>
  <div>

  </div>
</template>
<script>
import { defineComponent, getCurrentInstance } from 'vue'

export default defineComponent({
  name: 'About',
  setup(){
    const { proxy } = getCurrentInstance()
    console.log(proxy.$root.$route)
    console.log(proxy.$root.$router)
    return {}
  }
})
</script>

方式二:通過從路由中導入 useRoute useRouter 使用 route 和 router。

Html

import { defineComponent } from ‘vue'
import { useRoute, useRouter } from ‘vue-router'
export default defineComponent({
setup () {
const $route = useRoute()
const r o u t e r = u s e R o u t e r ( ) c o n s o l e . l o g ( router = useRouter() console.log(router=useRouter()console.log(route)
console.log($router)
}
})

附:Vue3中關于getCurrentInstance的大坑

開發中只適用于調試! 不要用于線上環境,否則會有問題!

解決方案:

方案1.

const instance = getCurrentInstance()
console.log(instance.appContext.config.globalProperties)

獲取掛載到全局中的方法

方案2.

const { proxy } = getCurrentInstance()

使用proxy線上也不會出現問題。

以上就是關于“vue3中的getCurrentInstance如何使用”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

东乡| 佛冈县| 蓬莱市| 邹城市| 浏阳市| 前郭尔| 宝鸡市| 元谋县| 尼玛县| 易门县| 南阳市| 阿拉善右旗| 富裕县| 正定县| 许昌市| 宜川县| 宜宾县| 鞍山市| 香格里拉县| 安丘市| 兴城市| 汤阴县| 南投市| 贵溪市| 普定县| 伊金霍洛旗| 建阳市| 湘潭市| 南川市| 永寿县| 神木县| 浪卡子县| 九寨沟县| 昌都县| 青海省| 定西市| 威远县| 聊城市| 呼伦贝尔市| 镇宁| 防城港市|