前端開發(fā)變量命名系列 - JavaScript篇_第1頁
前端開發(fā)變量命名系列 - JavaScript篇_第2頁
前端開發(fā)變量命名系列 - JavaScript篇_第3頁
前端開發(fā)變量命名系列 - JavaScript篇_第4頁
前端開發(fā)變量命名系列 - JavaScript篇_第5頁
已閱讀5頁,還剩16頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)

文檔簡介

JavaScript作為前端開發(fā)從業(yè)人員必須掌握的3大基礎(chǔ)知識中最重要的一環(huán),也

是平是接觸時間最長、寫得最多的。在開發(fā)過程中必然會遇到命名的問題,你會

詞窮、糾結(jié)、惆悵嗎?本文的出現(xiàn)相信能夠解決大部分煩惱,讓你輕松寫出符合

規(guī)范、易讀、簡短的代碼。

本文將通過大量的實例來試圖自圓其說,形成一套系統(tǒng)化、實用的變量命名理化

體系。通過按JavaScript的數(shù)據(jù)類型分類著手、細(xì)到一個函數(shù)的參數(shù)命名,并提

供眾多可選方案,并盡量給出其適用范圍和利弊。

需要注意的是由于個人寫作水平、和知識有限,很多方面敘述上有

些生硬,在分類上也沒有什么特別的依據(jù),文章也沒有人審稿,所

以有什么紙漏還請留言告知。由于寫作倉促,內(nèi)容可能不全,后續(xù)

會隨著工作和學(xué)習(xí)的深入而不斷地調(diào)整和更新。

布爾值(Boolean)命名

Boolean值是兩種邏輯狀態(tài)的變量,它包含兩個值:真和假。在JavaScript中對

應(yīng)true和false,在實踐中通常使用數(shù)字i表示真值,。來表示假值。

雖然Boolean的狀態(tài)只有兩種但是在命名時可以進一步分類,這里給出幾種場景:

場景一:表示可見性、進行中的狀態(tài)

解釋:可見性在通常指頁面中的元素、組件是否顯示(或者組件掛載到DOM上,

但并不可見)。進行中主要是說明某種狀態(tài)是處于持續(xù)進行中。

推薦命名方式為is+動詞(現(xiàn)在進行時)/形容詞,同時這種方式也可以直接不寫is,

但是為了更好的作區(qū)分,建議還是加上。

isSkow:'是否顯示I

泡是否可見。

kL?!φJ(rèn)g:'是否處于力口載中I

AC。八八cct/hg:'是否處于連接中一

以岫hg「正在驗證中「

kRuFming:,正在運行中I

isListening:,正在監(jiān)聽中,

)

注意:在Java中使用這種方式是有一定副作用的,為什么請移步:

為什么阿里巴巴禁止開發(fā)人員使用"isSuccess"作為變量名?

場景二:屬性狀態(tài)類

解釋:通常用來描述實體(例如:HTML標(biāo)簽、組件、對象)的功能屬性,而且

定法比較固定。

(

disabled:,是否禁用「

cditab/c」是否可編輯。

clearable:,是否可清除「

readonly:,只讀「

expande:受否可展開:

checked:,是否選中。

e八,儂帥e:,是否可枚舉二

itcsb他」是否可迭代。

cack〃b/e:,是否可點擊。

4小必地/0」是否可拖拽,

)

場景三:配置類、選項類

解釋:主要是指組件功能的開啟與關(guān)閉,功能屬性的配置。

這是一種比較常見的情景,目前命名方式也有很多種,但是歸納起來也不多。推

薦使用w汕Xx來表示組件在基本功能形態(tài)外的其它功能,比如組件的基礎(chǔ)功能

到高級功能的開啟;使用次加XX來表示組件某些功能的開啟;使用aHowXx來

表示功能屬性的配置;使用八。Xx用于建議功能使用者這個不建議開啟。

w/'tkTnb:,是否帶選項卡I

,不帶選項卡]

ei<\ableFilter:,開啟過濾「

allowk\Cu$toi^Scale:,允許自定義縮放一

s〃。川dC/ear:堤否清除「

caiaSelectlte^v\:'是否能選中元素一

八。C。/。八:'不顯示版后面的冒號一

MeckJs:'檢查Js「

em/tBOM:aUTF-8ByteOrderMark(J3OM)inthebeginningofoutputfiles/

)

注意:如果嫌分類太多,可以只使用其中一種方式,比如在

Typescript中使用了H/ownXx和noXx。

除了上面這些帶有特定的前置介詞、動詞方式外還有一些在語義上帶有疑問性質(zhì)

的組合通常也是作為Boolean命名的一種參考。

是否啟用虛擬滾動模式J

u^kPaMls:,在范圍選擇器里取消兩個日期面板之間的聯(lián)動一

KH以比cEvc八七輸入時是否觸發(fā)表單的校驗,

}

函數(shù)命名

函數(shù)在不同的上下文中的叫法也不一樣,在對象中稱為方法,在類中有構(gòu)造函數(shù)、

在異步處理時有回調(diào)函數(shù),還有立即執(zhí)行函數(shù)、箭頭函數(shù)、柯里函數(shù)等。

函數(shù)命名的方式常常是和業(yè)務(wù)邏輯耦合在一起的,但是在命名規(guī)則上也有一些常

見的模式可以遵循。

場景一:事件處理

事件處理函數(shù)是前端平時用到最多的,包括瀏覽器原生事件、異步事件和組件自

定義事件。在寫法上最常見的兩種命名分別為onXx、onXxC/ick和han山eXx、

hain.dle.X.xChavy.ge。

這里如何在二者之間選擇,可以從二方面來歸類。一是,原生事件采用。八Xx,

而自定義事件使用以八山eXx。二是,事件主動監(jiān)聽采用。八Xx,被動處理使

用handleXx。

從實踐及三大主流框架的文檔關(guān)于事件部分的內(nèi)容來看,推薦使用hasUeXx這種

方式,而在表單提交的時候通常采用onSuhvut函數(shù)。

其實,在實際項目中很少嚴(yán)格這樣來命名事件處理函數(shù),因為這種方式有一定的

局限性,比如點擊按鈕打開一個對話框,使用ka八山eOpenD/g和。八。penD/g者B沒有

直接寫叩八D/g方便,如果頁面有多個不同功能的對話框采用這種方式會顯得變

量名過長,而handle和on就顯得沒有必要了,比如hanldeOpenCoMMentDlg就

沒有opcnCoMAMentD/g直白。

下面列出了一些約定成俗的適用例子:

{

。八S〃匕⑼七,提交表單。

法md/eSizeCk〃八gc:'處理分頁頁數(shù)改變一

hai^dlePageCha^.ge:'處理分頁每頁大小改變二

。八Keydown:'按下鍵,

)

場景二:異步處理

這里主要是指在寫數(shù)據(jù)層服務(wù)、狀態(tài)管理中的Action命名,以及Ajax回調(diào)的命

名規(guī)則。

(

getUsers」獲取用戶列表)

fetc/VToke八」取得Token',

de/eteUse仁'刪除用戶一

rei^oveTag:'移除標(biāo)簽一

updntcU""F。:哽新用戶信息一

“ddU":,添加用戶I

createAcc?!╪t:嗆U建賬戶,

)

命名主要圍繞數(shù)據(jù)的增刪查找來劃分,獲取數(shù)據(jù)通常是gctXx和胱MXx,在作者

看來兩者在使用上的區(qū)分在于getXx的數(shù)據(jù)來源不一定直接取自異步的原始數(shù)

據(jù),可能是加工處理后的,而fetckXx是直接拿的原始數(shù)據(jù)。當(dāng)然在實際項目中

并沒有區(qū)分,看個人喜好。

念麻eXx主要用于數(shù)據(jù)刪除,而憶MweXx在語義上是移除數(shù)據(jù),通常情況數(shù)據(jù)是

還存在的,只是沒有顯示或數(shù)據(jù)假刪除。updateXx是指數(shù)據(jù)更新操作,addXx是

在已有列表數(shù)據(jù)中添加新的子項、而createXx主要是創(chuàng)建新的實例,比如新建一

個賬戶。

場景三:跳轉(zhuǎn)路由

在實際開發(fā)過種中,比如在使用react-router/vue-router時,在模板或者JSX中

可以直接在標(biāo)簽中寫上目標(biāo)地址,但有些時候跳轉(zhuǎn)的目標(biāo)地址是經(jīng)過判斷或者組

合后的,并且通過事件觸發(fā)跳轉(zhuǎn)的,這個時候就需要一個函數(shù)來處理,那么在函

數(shù)命名的時候可以考慮使用

切空步時疝)跳轉(zhuǎn)到模板詳情頁面I

八WoHohA。:,導(dǎo)航至IJ首頁一

。叫叫。出0:'跳轉(zhuǎn)首頁:

跳轉(zhuǎn)首頁「

redirectToLogii^:'重定向到登錄頁「

switc/VTZb:,切換Tab選項卡一

backHcw,回至ij主頁,

)

推薦使用toXx和goXx這兩種方式,如果不是在當(dāng)前頁面打開/跳轉(zhuǎn)頁面,可以使

用toBlankTplDetail或者goBlankHoMe這種方式來進一步語義化。如果前端頁面是

位于Webview中,也可以考慮采用toNativeShare這種方式來命名。

場景四:框架相關(guān)特定方法

這里主要是針對前端3大主流流行框架,有一些命名是帶有特定標(biāo)識符的,還有

就是一些生命周期的命名方式。

fori^atTii^\eFilter:,在A八gu/nrJsWVue中,通常用于過濾器命名「

stowC"/:,用于Ang川〃-Js定義控制器方法1

f。?vuatP/pc」用于中,標(biāo)識管道方法一

'Vue中的實例方法二

入八中的內(nèi)置方法)

beforeCreate:'Vue的生命周期命名。

coi^xpoMiatWillMouiat:'React生命周期命名

coi^xpoMiatDidMoui^t:'React生命周期命名I

afterCoi^teintti^it:'Ai^uglar生命周期命名「

afterViewClaecked:'Ai^gula生命周期命名I

httpProvidecA八gudanJs服務(wù)一

useKF〃ct"g:'工廠函數(shù)「

“scC〃他〃ck:,Re4ct鉤子函數(shù),

)

場景五:數(shù)據(jù)的加工

這類場景在處理列表的時候經(jīng)常會碰到,比如排序、過濾、添加額外的字段、根

據(jù)ID和索引獲取特定數(shù)據(jù)等。

情形一:根據(jù)特定屬性獲取屬性

這里口J以參考DOM方法的命名,比如:

getElew.&ntsByClassNai^e.Q和getElenae八tsBgNakv\e(),然后提煉出一個比較實用的模

板:gctXxBgYgO。其中Xx可以是:nt,(tern,option,data,selection,list,options以

及一些特定上下文的名字,比如:use心),⑸等。Yg相對來說比較固定,經(jīng)

常用到的就是id,index,key,value.,selected,actived等。

除了使用get,還可以使用que吆和fetch,但是需要注意和上面提到的異步數(shù)據(jù)

處理作一個區(qū)分。

get/tCkBgU:喉據(jù)IP獲取數(shù)據(jù)元素J

get/te3s89sHecteW:'根據(jù)傳入的已選列表ID來獲取列表全部數(shù)據(jù)。

quergUserBgUid:喉據(jù)U(P查詢用戶,

注意:在get/tekvxsBgSe/ecteW這種情形卜直接寫成get/tcsSe/ecteW更好,但只適用

于丫9為形容詞的場景

情形二:格式化數(shù)據(jù)

這里的格式化操作包括排序、調(diào)整數(shù)據(jù)結(jié)構(gòu)、過濾數(shù)據(jù)、添加屬性。命名通常使

用form?tXx,co八veHXx,my/erseXx,togg/eXx,parseXx,flatXx,也可以結(jié)合數(shù)組的一^些

操作方法來命名,比如sliceXx,subsWXx,spliceXx,sortXx,j。,八Xx等來命名。

FOMA淚?ate:,格式化日期二

。。八火力口”。八。9—轉(zhuǎn)換貨幣單位一

im/e”eUst:反轉(zhuǎn)數(shù)據(jù)列表I

togg/eAHSe/e&edL切換所有已選擇數(shù)據(jù)狀態(tài)一

pcKseXn/U:,解析XML數(shù)據(jù)I

他比:喂開選擇數(shù)據(jù)I

sortBgDesc」按降序排序,

數(shù)組命名

數(shù)組的命名推薦使用復(fù)數(shù)形式來命名,還有就是名詞和具有列表意思的單詞組合。

常見的詞匯有option,list,Maps,inodes,entities,collection.等。

users:'用戶列表一

useriJsi:'用戶列表L

僅。。呻。八s:,選項卡選項)

s僅笈Maps」?fàn)顟B(tài)映射表一

se/ectedNodes:,選中的節(jié)點]

況八GK?!??:,按鈕組1

userEntities:'用戶實體,

)

選項元素、下拉元素命名

主要針對的是在下拉選擇框、選項卡元素、Radio、Checkbox等數(shù)據(jù)源每個選項

數(shù)據(jù)的命名。常見的詞匯有:

title.,v\aw\e,key,label,field.,value,id,child.re.ia,im.de.Xiin.od.es等。

基中title/naMe/key/label/field作為選項顯示名,value/id用于唯一■標(biāo)識選項,

cMdr^odes用于包含子節(jié)點內(nèi)容。如果選項元素的語義很明確的情況下也可以

直接使用特定單詞來代替提到的這些泛指的詞匯,例如菜單列表就可以使

用wenu來作為顯示名。

//坡常見組合

(

tit/e:'標(biāo)題

value:'ID值,

)

//組合二

(

,標(biāo)簽名L

value:7P值'

1

//組合三

八,元素名。

id:'ID值'

//組合四

field:,字段,,

va/ue:'標(biāo)識',

index:嗦引,

1

當(dāng)前選項、激活項命名

適用列表的選中項、菜單選中項、步驟操作的當(dāng)前進行步驟、頁面路由當(dāng)前路由

等的命名。

〃比2打她:'當(dāng)前選中選項卡「

currMtPage:,當(dāng)前頁一

se/ectedD〃僅「當(dāng)前選項中數(shù)據(jù)一

臨時數(shù)據(jù)、比對數(shù)據(jù)命名

針對在代碼中有時會使用一些臨時的變量來存儲數(shù)據(jù)、保存數(shù)據(jù)快照的場景下的

命名。

(

swapDnt”:'臨時交換數(shù)據(jù)「

tekupDat〃:'臨時數(shù)據(jù)1

nnpskot:嗷據(jù)快照,

1

數(shù)據(jù)循環(huán)語句中變量命名

在使用f?!貉h(huán)時,多層嵌套請依次使用力/k,超過3層可以使用x/g/z,儂/八來

命名。使用£。在4曲小叩,的er等方法時,每一個元素命名可以根據(jù)不同語境下的

特殊名字來命名,比如遍歷儂enus,那么每個元素可以命名為3c不然則使用

上卜文無關(guān)的詞匯,比如:item,option,data,keyfobject等。至于索引通常使用index,

如果多層可以使用以Hex+數(shù)字的形式,也可以直接使用力/k來作為索引,甚至

還可以使用S(AbMdex/gm八山八dex這種方式來命名。

對于在使用for循環(huán)時數(shù)組長度如果需要單獨命名的話,可以使用xxlmgth/xS,

或者XXCounto

在循環(huán)的過程中通常還會統(tǒng)計某個條件下數(shù)據(jù)匹配的次數(shù)、重復(fù)元素數(shù)量、記錄

中間結(jié)果等情況。這里推薦使用。?!ò似弑硎敬螖?shù),Skipped表示跳過的數(shù)量,

result表示結(jié)果。

//for循環(huán)for(leti=。;i<工。;/+-+){

for(letj=O;j<IO;j++){

for(letk=O;k41。;k++){

//doSOHAC協(xié)/hg

}

}

)

For(leti=O,(e八s=this.opti。八s.(e八gth;i<他八s;i++)(

//dos。3c麗ng

)

//forEach

iASCd.foFEach((iteM,index)=>{

//doSON況hMg

1)

menus.index)=>{

if(kv\ei^(A.children){

MC"(.而以此八.foKEack((s〃bMe八〃,s〃b伉dcx)=>{

if(subMeiaiA.ckitdreia'){

s〃bMcnu.而〃七八.f"E〃ck((gKMdMcnu,gr^m山八dex)=>{

//一個不常用的示例

1)

)

1)

)

1)

方法參數(shù)命名

方法的參數(shù)名稱和數(shù)量在不同的方法中各不相同,但是還是有一些固定的模式可

以參考,比如在Vue中監(jiān)聽屬性變化的新值和舊值;reduce方法的上一個值,當(dāng)

前值;回調(diào)函數(shù)的命名、剩余參數(shù)的命名等。

情形一:新值、舊值

常見于Vue中watch對像中的屬性監(jiān)聽回調(diào)函數(shù),推薦使用

oldVal:*舊值一

newVH:,新值,

情形二:上一個值、下一個值和當(dāng)前值

這種情形見于路由的鉤子方法,。切ectassign數(shù)據(jù)拷貝的參數(shù)。

//組合一

from:從

亡?!傅?/p>

//組合二

pr&v:,上一個…。

八ext:,下一個

C":'當(dāng)前,

//組合三

source:'源「

僅燈況:'目標(biāo),

//組合四

start:'開始

eiad:,結(jié)束,

情形三:異步數(shù)據(jù)返回

用于Promise的彷e八方法參數(shù),await的返回的Promise等??蛇x擇的詞匯有:

res,data,jsoin.,entity?推薦使用res0

^emoProm/se.theH(res=>{

//dosomething

1)

情形四:其它情況

一些使用不多,但是在編程時約定成俗的命名方式。例如次表示單個字符,也表

示字符串,”代表次數(shù),『兩表示正則,expr表示表達(dá)式,怙八s表示數(shù)組長

度,count表示數(shù)量,P表示數(shù)據(jù)的精度,q表示查詢(query),src表示數(shù)據(jù)源

(source),八。表示數(shù)字(number),rate表示比率,status表示狀態(tài),boot表示布爾

值,?rr表示數(shù)組值,。句表示對象值,X和g表示坐標(biāo)兩軸,feme表示函數(shù),ua表示

UserAgent,size.表示大小,unit表示單位,Moz表示水平方向,vert表示垂直方

向,小歇表示基數(shù),根

//傳入單個字符fimetio八

//數(shù)&巾復(fù)functionrepeat(st匕八)

//亞則“?!?小磔公外/%Jb/)

事件命名

這里根據(jù)DOM、nodejs和一些框架和UI組件的事件進行歸納

DOM事件

這里列舉DOM中常見的事件命名

(

□ad:'已完成加載J

unload:'資源正在被卸載I

bcFo「e(x八load:,資源即將被卸載一

0”。匕:,失敗時「

“bort」中止時I

Focus:'元素獲得焦點:

blur.'元素失去焦點。

〃土:'己經(jīng)剪貼選中的文本內(nèi)容并且復(fù)制到了剪貼板。

copg:'已經(jīng)把選中的文本內(nèi)容復(fù)制到了剪貼板一

paste:,從剪貼板復(fù)制的文本內(nèi)容被粘貼、

resize:'元素重置大小「

scr?!薄笣L動事件:

reset:,重置「

他淪俵單提交。

。八“八c:農(nóng)線L

offline:,離線,

ope八:'打開「

dose:'關(guān)閉I

confect:'連接,

start:,開始、

e八結(jié)束一

所八七一打印I

aftre3九八土一打印機關(guān)閉時觸發(fā)一

click:,點擊。

d勿c〃ck」雙擊「

Mange」變動一

select:'文本被選中被選中I

kcgdow八/keg/"ess/keg〃p-按鍵事件「

touch:,輕按1

c。八,右鍵點擊(右鍵菜單顯示前)。

wkee/」?jié)L輪向任意方向滾動J

p。阮ter:,指針事件I

d「〃g/dKagst〃rt/drage八d/drage八七?!?憶0。\/0〃4匕49/0〃/。:,拖放事件「

drop:'元素在有效釋放目標(biāo)區(qū)上釋放I

p/ag:'播放「

pause:'暫停',

suspcnd:,掛起。

,。小川況e:,完成。

seek」搜索「

install:,安裝。

progress:'進行一

broadcast:

i叩戊:輸入I

message「消息',

valid:'有效一

ZOOM:,放大I

state:'旋轉(zhuǎn)

“He—縮放I

upgrade:更新I

憶〃準(zhǔn)備好「

active:

]

自定義事件

在封裝組件時提供的事件名除了參考DOM事件外,在命名上也可以參考Github

Api采用動詞過去時+Event的方式,VisualStudioCodeApi的'on+

assighedEse八七」分配事件一

c/osedE"

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論