亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

關(guān)于vue3?option?api新玩法分享

 更新時間:2022年06月23日 15:31:28   作者:CharTen  
vue3新特性中最重要、內(nèi)容最多的組合式api,組合式api既可以解決之前vue2開發(fā)的痛點,又提升了性能,下面這篇文章主要給大家介紹了關(guān)于vue3?option?api新玩法的相關(guān)資料,需要的朋友可以參考下

可能一些朋友看到標(biāo)題,瞬間就不淡定了,vue3+option api,在大家都在使用setup做組合式API的今天,這不就是開歷史的倒車嗎?別急啊,我們這么做,也是有苦衷的。

這是2個月之前在一篇介紹script setup的文章里面,我發(fā)布一個評論。事情就如同評論所說,考慮到成員之間水平不一樣,太靈活了,你寫代碼煮面條我也煮面條,彼此之間反而互相看不懂代碼了。那做eslint規(guī)范約束吧,約束到最后得到一個長得像option api但效果又沒有option api好的規(guī)范,最終團隊默默退回了option api了。

可能有些朋友還不知道什么是option api,什么是setup吧?這里先簡單解釋一下,所謂option api,就是vue2的那套寫法:

export default {
    data(){
        return {/*...*/}
    },
    methods:{},
    mounted(){}
}

而所謂script setup或者組合式api,是vue3的一個新寫法,它允許我們在setup作用域下完成整個頁面的邏輯編寫:

export default defineComponent({
    setup(){
        const a = ref(0)
        onMounted(()=>{
            a.value = 100
        })
        return {
            a
        }
    }
})

// 或者在<script setup>里面直接寫
const a = ref(0)
onMounted(()=>{
    a.value = 100
})

正當(dāng)我們感嘆時代變化真快,團隊無法在時代的新潮流玩耍的時候,一個突入其來的bug,為團隊成員打開了新思路。

事情是這樣的,團隊一個成員在做組件集成monaco editor(一個微軟開發(fā)的代碼編輯器組件)的時候,發(fā)現(xiàn)退出頁面的時候直接將瀏覽器卡死了。一般瀏覽器卡死,肯定是js死循環(huán)造成的,于是整個團隊開始對他的代碼進行review,仔細檢查每一處循環(huán),查看每一處判斷條件,生怕漏了哪一個可能照成判斷逃逸導(dǎo)致循環(huán)無法停止的地方。

然而他的代碼在option api下顯得規(guī)規(guī)矩矩,review起來通俗易懂,在代碼實現(xiàn)上找不到可以挑剔的地方。但是卡死瀏覽器的問題依然存在,總不該是vue3或者是monaco的問題吧?于是祭出注釋debug法,從beforeUnmount開始注釋掉:

export default defineComponent({
  ...
  beforeUnmount() {
  //   console.log("dispose");
  //   this.edt && this.edt.dispose();
  }
})

this.edt是monaco editor的實例對象。真的是幸運,第一次注釋就找到原因,退出頁面不卡死了。但是引起瀏覽器卡死的,是monaco的釋放內(nèi)存?

這肯定不可能,于是我重新讀代碼,直到眼光放在this.edt的聲明上:

export default defineComponent({
  data(){
      return {
          ...
          edt:null as editor.IStandaloneCodeEditor|null
      }
  }
  ...
  mounted(){
      this.edt = editor.create(...)
  }
})

注釋掉data里面的edt聲明,同時恢復(fù)在beforeUnmount時釋放內(nèi)存。這時候ts拋錯了,edt在this里面不存在。好在vite并不會理會ts的錯誤,頁面正常運行,退出時也不會引起瀏覽器卡死。那么答案呼之欲出,罪魁禍首就是你,vue的響應(yīng)式變量功能!我猜測是monaco的editor實例里有一堆相互引用的屬性,原本沒有proxy的情況下,銷毀就銷毀了,但是加上了vue的proxy之后,相互引用層層嵌套導(dǎo)致一直無法銷毀造成死循環(huán)。

而在vue2寫js的時候,這些第三方庫都是很隨便的用一個運行時this.xxx去掛載。但是vue3對ts的支持加強,團隊開始使用ts,之前運行時this.xxx的用法會報錯,于是很多成員為了解決這個錯誤,同時又想獲得類型提示,就直接在data里面聲明這個屬性。

像這次,就是將第三方庫操作對象掛載在data里面,恰好跟proxy結(jié)合導(dǎo)致bug的發(fā)生。既然在沒有proxy的環(huán)境下執(zhí)行是正常的,那么option api里有沒有可以掛載無響應(yīng)屬性的地方呢?

“為什么不直接掛在setup里面呢?setup里面的變量不加ref的話是沒有響應(yīng)式的,我們不在setup里面寫邏輯,不代表我們不能用setup呀。”

團隊里面另一位成員一語驚醒夢中人:

export default defineComponent({
  setup(){
      const edt:editor.IStandaloneCodeEditor|null = null
      return {
          edt
      }
  },
  data(){
      return {
          ...
          // edt:null as editor.IStandaloneCodeEditor|null
      }
  }
  ...
  mounted(){
      this.edt = editor.create(...)
  },
  beforeUnmount() {
      console.log("dispose");
      this.edt && this.edt.dispose();
  }
})

這樣,ts不報錯了,也可以進行類型提示。頁面也不卡死了,第三庫如愿以償?shù)脑跊]有proxy的作用下運行。會寫hook的同學(xué)笑了,后面可以把邏輯抽象到ts里面了。組合式api寫不好的同學(xué)也沒有灰心,因為還是在他熟悉的option api體系下開發(fā),而且可以寫得更加出色。

把setup當(dāng)作option api的一部分,把不會用到模板里的變量掛在setup里,把頁面模板會用到的變量掛在data里,而通過this都能訪問到兩者,也可以為兩者提供類型檢查。相比vue2來說,團隊成員代碼里不會再出現(xiàn)運行時掛載最終導(dǎo)致相互覆蓋的事情發(fā)生,這無疑已經(jīng)是一個巨大的進步。

這就是我要說的option api的新玩法,也是vue3的新功能。因為團隊的不適應(yīng),暫時放棄了setup里寫邏輯的能力,改用于掛載非響應(yīng)式變量和抽象出來的hook。

但更重要的是我們要有一個認識,在代碼世界里面沒有必要把事物對立起來,彼此之間都有長處,那應(yīng)該是取決于自身的情況把彼此的長處容納進來,即不要為了新而新,也無須因為舊而排斥,適合自己的才是最好的。

總結(jié)

到此這篇關(guān)于vue3 option api新玩法的文章就介紹到這了,更多相關(guān)vue3 option api新玩法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue單個組件實現(xiàn)無限層級多選菜單功能

    vue單個組件實現(xiàn)無限層級多選菜單功能

    這篇文章主要介紹了vue單個組件實現(xiàn)無限層級多選菜單的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-04-04
  • vue使用@include或@mixin報錯的問題及解決

    vue使用@include或@mixin報錯的問題及解決

    這篇文章主要介紹了vue使用@include或@mixin報錯的問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • 5個可以加速開發(fā)的VueUse函數(shù)庫(小結(jié))

    5個可以加速開發(fā)的VueUse函數(shù)庫(小結(jié))

    VueUse為Vue開發(fā)人員提供了大量適用于Vue2和Vue3的基本Composition API 實用程序函數(shù)。具有一定的參考價值,感興趣的可以了解一下
    2021-11-11
  • ant?菜單組件報錯Cannot?read?property?‘isRootMenu‘?of?undefined

    ant?菜單組件報錯Cannot?read?property?‘isRootMenu‘?of?undefin

    這篇文章主要介紹了ant?菜單組件報錯Cannot?read?property?‘isRootMenu‘?of?undefined解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • 淺談webpack編譯vue項目生成的代碼探索

    淺談webpack編譯vue項目生成的代碼探索

    本篇文章主要介紹了淺談webpack編譯vue項目生成的代碼探索,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • Vue組件間的通信方式詳析

    Vue組件間的通信方式詳析

    本文介紹Vue組件間通信方式,Vue組件間通信一直是個重要的話題,雖然官方推出的Vuex狀態(tài)管理方案可以很好的解決組件之間的通信問題,但是在組件庫內(nèi)部使用Vuex往往會比較重,本文將系統(tǒng)的羅列出幾種不使用Vuex,比較實用的組件間的通信方式,希望能幫助到大家
    2022-09-09
  • Vue中組件遞歸及使用問題

    Vue中組件遞歸及使用問題

    這篇文章主要介紹了Vue中組件的遞歸和使用問題,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • Vue通過WebSocket建立長連接的實現(xiàn)代碼

    Vue通過WebSocket建立長連接的實現(xiàn)代碼

    這篇文章主要介紹了Vue通過WebSocket建立長連接的實現(xiàn)代碼,文中給出了問題及解決方案,需要的朋友可以參考下
    2019-11-11
  • vue template中slot-scope/scope的使用方法

    vue template中slot-scope/scope的使用方法

    今天小編就為大家分享一篇vue template中slot-scope/scope的使用方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • .env在mode文件中如何添加注釋詳解

    .env在mode文件中如何添加注釋詳解

    這篇文章主要為大家介紹了.env在mode文件中如何添加注釋詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09

最新評論