命名規則--爲什麼文件名要小寫

分類

 

爲什麼文件名要小寫?

作者: 阮一峯

日期: 2017年2月10日

珠峯培訓

上週,《中文技術文檔寫作規範》加入了文件的命名規則。

"文件名建議只使用小寫字母,不使用大寫字母。"

"爲了醒目,某些說明文件的文件名,可以使用大寫字母,比如READMELICENSE。"

網友看見了,就提問爲什麼文件名要小寫?

說實話,雖然這是 Linux 傳統,我卻從沒認真想過原因。趕緊查資料,結果發現四個很有說服力的理由,支持這樣做。

下面就是這四個理由。另外,文後我還會發布一條前端培訓的消息。

一、可移植性

Linux 系統是大小寫敏感的,而 Windows 系統和 Mac 系統正好相反,大小寫不敏感。一般來說,這不是大問題。

但是,如果兩個文件名只有大小寫不同,其他都相同,跨平臺就會出問題。

  • foobar
  • Foobar
  • FOOBAR
  • fOObAr

上面四個文件名,Windows 系統會把它們都當作foobar。如果它們同時存在,你可能沒辦法打開後面三個文件。

另一方面,在 Mac 系統上開發時,有時會疏忽,寫錯大小寫。


// 正確文件名是 MyModule.js
const module = require('./myModule');

上面的代碼在 Mac 上面可以運行,因爲 Mac 認爲MyModule.jsmyModule.js是同一個文件。但是,一旦代碼到服務器運行就會報錯,因爲 Linux 系統找不到myModule.js

如果所有的文件名都採用小寫,就不會出現上面的問題,可以保證項目有良好的可移植性。

二、易讀性

小寫文件名通常比大寫文件名更易讀,比如accessibility.txt就比ACCESSIBILITY.TXT易讀。

有人習慣使用駝峯命名法,單詞的第一個字母大寫,其他字母小寫。這種方法的問題是,如果遇到全部是大寫的縮略詞,就會不適用。

比如,一個姓李的紐約特警,無論寫成NYPoliceSWATLee還是NyPoliceSwatlee,都怪怪的,還是寫成ny-police-swat-lee比較容易接受。

三、易用性

某些系統會生成一些預置的用戶目錄,採用首字母大寫的目錄名。比如,Ubuntu 在用戶主目錄會默認生成Downloads、 PicturesDocuments等目錄。

Mac 系統更過分,一部分系統目錄也是大寫的,比如/Library/Audio/Apple Loops/

另外,某些常見的配置文件或說明文件,也採用大寫的文件名,比如MakefileINSTALLCHANGELOG.Xclients.Xauthority等等。

所以,用戶的文件都採用小寫文件名,就很方便與上面這些目錄或文件相區分。

如果你打破砂鍋問到底,爲什麼操作系統會採用這樣的大寫文件名?原因也很簡單,因爲早期 Unix 系統上,ls命令先列出大寫字母,再列出小寫字母,大寫的路徑會排在前面。因此,如果目錄名或文件名是大寫的,就比較容易被用戶首先看到。

四、便捷性

文件名全部小寫,還有利於命令行操作。比如,某些命令可以不使用-i參數了。


# 大小寫敏感的搜索
$ find . -name abc
$ locate "*.htmL"

# 大小寫不敏感的搜索
$ find . -iname abc
$ locate -i "*.HtmL"

另外,大寫字母需要按下 Shift 鍵,多多少少有些麻煩。如果文件名小寫,就不用碰這個鍵了,不僅省事,還可以提高打字速度。

程序員長時間使用鍵盤,每分鐘少按幾次 Shift,一天下來就可以省掉很多手指動作。長年累月,也是對自己身體的一種保護。

綜上所述,文件名全部使用小寫字母和連詞線(all-lowercase-with-dashes),是一種值得推廣的正確做法。

(正文完)

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章