欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue組件的Prop命名約定詳解

 更新時(shí)間:2023年08月11日 10:56:33   作者:王大冶  
這篇文章主要為大家介紹了Vue組件的Prop命名約定詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

引言

在編程中,有兩個(gè)極具挑戰(zhàn)性的任務(wù):緩存失效和命名事物。今天,我們將深入探討后者,探索為Vue組件命名props的藝術(shù)。

在給 props 命名時(shí),遵循已有的變量命名慣例是非常重要的。例如,使用小駝峰命名法(isEnabled)并保持名稱簡短(不超過30個(gè)字符)。

然而,Vue有自己的一套最佳實(shí)踐,我們應(yīng)該遵循。讓我們根據(jù)我在使用Vue的經(jīng)驗(yàn)談?wù)勔恍┘记伞?/p>

1.內(nèi)容感知命名

重要的是最大限度地利用變量名傳達(dá)信息,以減少混淆并使組件的瀏覽更加容易。

對(duì)于數(shù)組,選擇使用復(fù)數(shù)名詞作為變量名,例如 items 。這個(gè)選擇立即表明該變量代表一組相關(guān)元素的集合。

處理數(shù)字時(shí),可以使用前綴如 num 或后綴如 count 和 index 來表示數(shù)值。例如, numItems , itemCount 和 itemIndex 可以清楚地表明變量的數(shù)值屬性。

在處理對(duì)象時(shí),請(qǐng)使用適當(dāng)?shù)膯螖?shù)名詞,例如 item 。

對(duì)于布爾值,請(qǐng)使用描述性前綴如 is 、 can 和 has 來傳達(dá)視覺或行為上的變化:

is 適用于表示視覺或行為狀態(tài),例如 isVisible , isEnabled 或 isActive 。

can 表示行為變化或條件性的視覺變化??紤]使用 canToggle 或 canExpand 這樣的屬性名稱來清晰地表達(dá)組件的能力。

has 表示UI元素的存在。使用前綴如 hasCancelButton 或 hasHeader 來表示特定的UI元素是否存在或可見。

2. 描述性命名

Props 應(yīng)該描述組件本身,側(cè)重于它的功能而不是為什么要這樣做。避免以當(dāng)前用戶或環(huán)境命名 props。

例如:

考慮使用 hasSubmitButton ,而不是 hasSubmitPermission

<MyForm hasSubmitButton="user.canSubmit" />

不要選擇 isMobileScreen ,而是選擇 isCompactLayout 。

<MyForm isCompactLayout="browser.isMobileScreen" />

避免將 props 命名為子組件。如果這些 props 是用來傳遞給子組件的,請(qǐng)使用描述組件本身的名稱。

  • 使用 <MyList @onItemClick="…" /> 代替 <MyList @onClick="…" />
  • 選擇 isLoadingComments 而不是 areCommentsLoading

描述子組件的存在可能會(huì)引起誤解。如果目標(biāo)是為了為圖標(biāo)創(chuàng)建更多的空間而不是切換其存在,考慮使用 isSpacious 而不是 hasIcon 。記住, hasIcon 回答的是為什么,而不是什么。

3. 事件處理程序?qū)傩?/h2>

在表示事件處理程序的屬性名稱之前添加 on (例如,onSelect,onClick

使用 handle 前綴來定義處理函數(shù)。

<MyComp @onClick="handleClick" />

避免在自定義事件中使用內(nèi)置的事件處理程序?qū)傩悦Q。如果原生的焦點(diǎn)/點(diǎn)擊事件不相關(guān),請(qǐng)使用自定義名稱,例如 onSelect ,而不是 onFocus 或 onClick 。

按照這些準(zhǔn)則,我們可以為Vue應(yīng)用程序建立一致且有意義的 prop 命名約定。周到的 prop 名稱有助于提高代碼的可讀性和可維護(hù)性,使你和團(tuán)隊(duì)更容易有效地合作。

以上就是Vue組件的Prop命名約定詳解的詳細(xì)內(nèi)容,更多關(guān)于Vue組件Prop命名約定的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 深入理解vue3中的reactive()

    深入理解vue3中的reactive()

    本文主要介紹了深入理解vue3中的reactive(),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • Vue2使用cube-ui?實(shí)現(xiàn)搜索過濾、高亮功能

    Vue2使用cube-ui?實(shí)現(xiàn)搜索過濾、高亮功能

    cube-ui?是基于?Vue.js?實(shí)現(xiàn)的精致移動(dòng)端組件庫,由于很長一段時(shí)間沒有學(xué)習(xí)cube-ui?的功能實(shí)現(xiàn)示例代碼了,今天通過本文給大家介紹下Vue2使用cube-ui?實(shí)現(xiàn)搜索過濾、高亮功能,感興趣的朋友跟隨小編一起看看吧
    2023-01-01
  • 網(wǎng)站國際化多語言處理工具i18n安裝使用方法圖文詳解

    網(wǎng)站國際化多語言處理工具i18n安裝使用方法圖文詳解

    國際化是設(shè)計(jì)軟件應(yīng)用的過程中應(yīng)用被使用與不同語言和地區(qū),下面這篇文章主要給大家介紹了關(guān)于網(wǎng)站國際化多語言處理工具i18n安裝使用方法的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • Vue實(shí)現(xiàn)手機(jī)計(jì)算器

    Vue實(shí)現(xiàn)手機(jī)計(jì)算器

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)手機(jī)計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • vuejs手把手教你寫一個(gè)完整的購物車實(shí)例代碼

    vuejs手把手教你寫一個(gè)完整的購物車實(shí)例代碼

    這篇文章主要介紹了vuejs-手把手教你寫一個(gè)完整的購物車實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • Element?UI中table單元格合并的解決過程

    Element?UI中table單元格合并的解決過程

    element?ui中的table表格數(shù)據(jù)是動(dòng)態(tài)生成的,最近遇到個(gè)需求,要求我們對(duì)單元格進(jìn)行合并,所以下面這篇文章主要給大家介紹了關(guān)于Element?UI中table單元格合并的解決過程,需要的朋友可以參考下
    2022-08-08
  • Vue el-autocomplete遠(yuǎn)程搜索下拉框并實(shí)現(xiàn)自動(dòng)填充功能(推薦)

    Vue el-autocomplete遠(yuǎn)程搜索下拉框并實(shí)現(xiàn)自動(dòng)填充功能(推薦)

    在elementui Input輸入框中可以找到遠(yuǎn)程搜索組件,獲取服務(wù)端的數(shù)據(jù)。這篇文章主要給大家介紹Vue el-autocomplete遠(yuǎn)程搜索下拉框并實(shí)現(xiàn)自動(dòng)填充功能,感興趣的朋友一起看看吧
    2019-10-10
  • vue如何給組件動(dòng)態(tài)綁定不同的事件

    vue如何給組件動(dòng)態(tài)綁定不同的事件

    這篇文章主要介紹了vue如何給組件動(dòng)態(tài)綁定不同的事件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue混入使用和選項(xiàng)合并詳解

    Vue混入使用和選項(xiàng)合并詳解

    這篇文章主要介紹了Vue混入使用和選項(xiàng)合并,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2021-10-10
  • Vue精簡版風(fēng)格概述

    Vue精簡版風(fēng)格概述

    本篇文章給大家講解了一下Vue精簡版風(fēng)格的相關(guān)知識(shí)點(diǎn)內(nèi)容以及分享了實(shí)例代碼,有興趣的朋友參考下。
    2018-01-01

最新評(píng)論