首頁 > 軟體

關於vue3 解決getCurrentInstance 打包後線上環境報錯問題

2022-05-24 18:01:38

getCurrentInstance

getCurrentInstance 支援存取內部元件範例。

WARNING

getCurrentInstance 只暴露給高階使用場景,典型的比如在庫中。強烈反對在應用的程式碼中使用 getCurrentInstance。請不要把它當作在組合式 API 中獲取 this 的替代方案來使用。

import { getCurrentInstance } from 'vue'
const MyComponent = {
  setup() {
    const internalInstance = getCurrentInstance()
 
    internalInstance.appContext.config.globalProperties // 存取 globalProperties
  }
}

列印資訊: 

getCurrentInstance 只能在setup或生命週期勾點中呼叫。 

如需在 setup或生命週期勾點外使用,請先在 setup 中呼叫 getCurrentInstance() 獲取該範例然後再使用。

setup() {
    const internalInstance = getCurrentInstance() // 有效
 
    const id = useComponentId() // 有效
 
    const handleClick = () => {
      getCurrentInstance() // 無效
      useComponentId() // 無效
 
      internalInstance // 有效
    }
}

本地使用範例:

當前在本地使用沒有問題,線上環境會報錯,不建議使用

<script>
    import {getCurrentInstance} from "vue";
    export default {
      components: {
      },
      setup() {
         const {ctx} = getCurrentInstance();
         console.log(ctx,"屬性1")
         
  
      }
</script>

檢視列印:

專案中使用:表單table列表查詢

方法1: 不推薦

setup() {
         const {ctx} = getCurrentInstance();
         console.log(ctx,"屬性1")
         
        //表單查詢方法
        const submitForm = (formName) =>{
          ctx.$refs[formName].validate(valid => {
            if (valid) {
              ruleForm.pageNum = 1;
              getTableData();
            } else {
              console.log("error submit!!");
              return false;
            }
          });
        }
}

 方法2:推薦此用法,才能在你專案正式上線版本正常執行,避免線上報錯問題

解決:用proxy代替ctx。在結構的時候直接將proxy解構出來

setup() {
         let {proxy} = getCurrentInstance();
        console.log(proxy,"屬性2");
         
        //表單查詢方法
        const submitForm = (formName) =>{
          proxy.$refs[formName].validate(valid => {
            if (valid) {
              ruleForm.pageNum = 1;
              getTableData();
            } else {
              console.log("error submit!!");
              return false;
            }
          });
        }
}

列印:

到此這篇關於vue3 解決getCurrentInstance 打包後線上環境報錯問題的文章就介紹到這了,更多相關vue3 getCurrentInstance 打包報錯內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com