国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

前端代碼風(fēng)格

diabloneo / 3069人閱讀

摘要:聲明順序相關(guān)的屬性聲明應(yīng)該以下面的順序分組處理盒模型排版外觀處在第一位,因為他可以使一個元素脫離正常文本流,并且覆蓋盒模型相關(guān)的樣式。關(guān)于完整的屬性以及他們的順序,請參考命名保持命名為全小寫,可以使用短劃線不要使用下劃線和命名。

文件名

均采用小寫方式, 以中劃線分隔, 如有復(fù)數(shù)結(jié)構(gòu)時,采用復(fù)數(shù)命名法

目錄名:scripts,styles,images,data-models

文件名: example.js retina-sprites.css

Javascript 注釋 何時使用

難于理解的代碼段

可能存在錯誤的代碼段

瀏覽器特殊的HACK代碼

想吐槽的產(chǎn)品邏輯, 合作同事

業(yè)務(wù)邏輯強(qiáng)相關(guān)的代碼

// 單行注釋斜杠后面要留有一個空格

/*
 * 多行注釋最少三行,注釋內(nèi)容與星標(biāo)前保留一個空格
 */
 
 var hello = "";        // 描述變量可以這樣寫在變量右邊
 
/*
 * 描述方法(函數(shù))必須使用多行描述
 * 如有必要可以加上參數(shù)和返回值說明,參考 http://usejsdoc.org/
 * @param {Object} balabalabala
 * @return {Object} balabalabala
 */
 function foo() {
     // 描述下面代碼時做什么的,方法第一行不需要留空格
     doSomething();
     
     // 描述下面代碼時做什么的,上方需要留一個空行
     afterDoSomething();
     
     if (flag) {
         // 描述下面代碼時做什么的,代碼塊的第一行也不需要留空格
         drive();
     }
 }
語法

使用四個空格的 soft tabs — 這是保證代碼在各種環(huán)境下顯示一致的唯一方式。

一般情況下 有關(guān)鍵字的地方都要有空格

字符串使用單引號而不是雙引號:`var str = "hello world";`

單行長度,理論上不要超過80列,不過如果編輯器開啟 soft wrap 的話可以不考慮單行長度

接上一條,如果需要換行,存在操作符的情況,一定在操作符后換行,然后換的行縮進(jìn)4個空格

這里要注意,如果是多次換行的話就沒有必要繼續(xù)縮進(jìn)了,比如說下面這種就是最佳格式。

if (typeof qqfind === "undefined" ||
    typeof qqfind.cdnrejected === "undefined" ||
    qqfind.cdnrejected !== true) {
    url = "http://pub.idqqimg.com/qqfind/js/location4.js";
} else {
    url = "http://find.qq.com/js/location4.js";
}
創(chuàng)建Object對象
// Bad
var team = new Team();
team.title = "AlloyTeam";
team.count = 25;

// Good  
var team = {
    title: "AlloyTeam",        // 冒號后需要跟一個空格
    count: 25
};
創(chuàng)建Array對象
// Bad
var colors = new Array("red", "green", "blue");
var numbers = new Array(1, 2, 3, 4);

// Good
var colors = [ "red", "green", "blue" ];  // 中括號左右均需要一個空格
var numbers = [ 1, 2, 3, 4 ];
構(gòu)造函數(shù)
/**
 * 創(chuàng)建一個構(gòu)造函數(shù)
 */
function Modal(options) {    // 函數(shù)名使用大寫字母開頭,駝峰式命名
    this.width = options.width;    // 屬性在構(gòu)造函數(shù)體中定義
    this.height = options.height;
}

Modal.prototype.show = function() {    // 方法定義在原型鏈上
    // show
}

Modal.prototype.hide = function() {
    // hide
}

// 實例化對象
var modal = new Modal({
        width: 200,
        height: 300
    });
if 語法
// if else 前后留有空格,
if (flag) {

} else {

}
for 語法
// 普通for
var values = [ 1, 2, 3, 4, 5, 6, 7 ],
    i, len;
for (i=0, len=values.length; i
switch 語法
// switch和括號之間有空格, case需要縮進(jìn), break之后跟下一個case中間留一個空行
switch (condition) {
    case "first":
        // code
        break;

    case "third":
        // code
        break;

    default:
    // code
}

// 沒有default的情況需要注釋特別說明
switch(condition) {
    case "first":
        // code
        break;

    case "second":
        // code
        break;

    // no default
}
聲明 變量聲明
var _body = $(document.body); // 全局變量使用下劃線 _ 開頭
function foo() {
    var result,    // 一個代碼塊里的變量聲明只用一個var
         length,    // 一個變量一行,行末跟注釋
         mainWrap;// 駝峰式命名法
         
}
常量聲明

使用全大寫字母+下劃線的命名方式方式

var IMAGE_DOMAIN = "WWW.XXX.COM";     
函數(shù)聲明

函數(shù)聲明統(tǒng)一使用function命令進(jìn)行聲明

// good
function foo() {        // 小括號前不需要空格,小括號與大括號間需要一個空格
    doSomething(); // 函數(shù)調(diào)用括號前后不需要空格
    return "hello world";
}

// bad
var foo = function() {
    return "hello world";
}

// bad
var foo = new Function(
    "return "hello world""
);

立即執(zhí)行函數(shù)的寫法, 最外層必須包一層括號

// Good
(function() {
    "use strict";    // 使用嚴(yán)格模式

    function doSomething() {
        // code
    }

    function doSomethingElse() {
        // code
    }

})();
空行

說明:下面代碼中的注釋處代表著實際代碼中的空行

function foo1() {
    
}
// 方法之間加空行
function foo2() {
    
}
// 邏輯塊與方法之間加空行增加可讀性
for (var i=0; i<10; i++) {
    
} 
// 邏輯塊之間加空行增加可讀性
if (flag) {
    
} else {
    
}
// 文件結(jié)尾留一個空行
雜項

只有字符串類型允許使用 == !=,如if(x == "a") 其他情況一律用嚴(yán)格比較條件 === !==

eval 非特殊業(yè)務(wù), 禁用!?。?/p>

with 非特殊業(yè)務(wù), 禁用?。。?/p>

CSS 語法

使用組合選擇器時,保持每個獨(dú)立的選擇器占用一行。

為了代碼的易讀性,在每個聲明的左括號前增加一個空格。

聲明塊的右括號應(yīng)該另起一行。

每條聲明 : 后應(yīng)該插入一個空格。

每條聲明應(yīng)該只占用一行來保證錯誤報告更加準(zhǔn)確。

所有聲明應(yīng)該以分號結(jié)尾。雖然最后一條聲明后的分號是可選的,但是如果沒有他,你的代碼會更容易出錯。

逗號分隔的取值,都應(yīng)該在逗號之后增加一個空格。比如說box-shadow

不要在顏色值 rgb() rgba() hsl() hsla()和 rect() 中增加空格

不要帶有取值前面不必要的 0 (比如,使用 .5 替代 0.5)。

所有的十六進(jìn)制值都應(yīng)該使用小寫字母,例如 #fff。因為小寫字母有更多樣的外形,在瀏覽文檔時,他們能夠更輕松的被區(qū)分開來。

為選擇器中的屬性取值添加引號,例如 input[type="text"]。 他們只在某些情況下可有可無,所以都使用引號可以增加一致性。

不要為 0 指明單位,比如使用 margin: 0; 而不是 margin: 0px;。

/* Bad CSS */
.selector, .selector-secondary, .selector[type=text] {
    padding: 15px;
    margin: 0px 0px 15px;
    background-color: rgba(0, 0, 0, 0.5);
    box-shadow: 0 1px 2px #C0C0C0, inset 0 1px 0 #F8F8F8
}

/* Good CSS */
.selector,
.selector-secondary,
.selector[type="text"] {
    padding: 15px;
    margin-bottom: 15px;
    background-color: rgba(0,0,0,.5);
    box-shadow: 0 1px 2px #c0c0c0, inset 0 1px 0 #f8f8f8;
}
聲明順序

相關(guān)的屬性聲明應(yīng)該以下面的順序分組處理:

Positioning

Box model 盒模型

Typographic 排版

Visual 外觀

Positioning 處在第一位,因為他可以使一個元素脫離正常文本流,并且覆蓋盒模型相關(guān)的樣式。盒模型緊跟其后,因為他決定了一個組件的大小和位置。

其他屬性只在組件 內(nèi)部 起作用或者不會對前面兩種情況的結(jié)果產(chǎn)生影響,所以他們排在后面。

關(guān)于完整的屬性以及他們的順序,請參考 Recess

.declaration-order {
    /* Positioning */
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 100;

    /* Box-model */
    display: block;
    float: right;
    width: 100px;
    height: 100px;

    /* Typography */
    font: normal 13px "Helvetica Neue", sans-serif;
    line-height: 1.5;
    color: #333;
    text-align: center;

    /* Visual */
    background-color: #f5f5f5;
    border: 1px solid #e5e5e5;
    border-radius: 3px;

    /* Misc */
    opacity: 1;
}
Class 命名

保持 Class 命名為全小寫,可以使用短劃線(不要使用下劃線和 camelCase 命名)。短劃線應(yīng)該作為相關(guān)類的自然間斷。(例如,.btn.btn-danger)。

避免過度使用簡寫。.btn 可以很好地描述 button,但是 .s 不能代表任何元素。

使用 .js-* classes 來表示行為(相對于樣式),但是不要在 CSS 中包含這些 classes。

/* Bad example */
.t { ... }
.red { ... }
.header { ... }

/* Good example */
.tweet { ... }
.important { ... }
.tweet-header { ... }
選擇器

使用 classes 而不是通用元素標(biāo)簽來優(yōu)化渲染性能。

避免在經(jīng)常出現(xiàn)的組件中使用一些屬性選擇器 (例如,[class^="..."])。瀏覽器性能會受到這些情況的影響。

減少選擇器的長度,每個組合選擇器選擇器的條目應(yīng)該盡量控制在 3 個以內(nèi)。

只在必要的情況下使用后代選擇器 (例如,沒有使用帶前綴 classes 的情況).

/* Bad example */
span { ... }
.page-container #stream .stream-item .tweet .tweet-header .username { ... }
.avatar { ... }

/* Good example */
.avatar { ... }
.tweet-header .username { ... }
.tweet .avatar { ... }
不要使用 @import

標(biāo)簽相比,@import 指令要慢很多,不光增加了額外的請求次數(shù),還會導(dǎo)致不可預(yù)料的問題。替代辦法有以下幾種:

使用多個 元素

通過 Sass 或 Less 類似的 CSS 預(yù)處理器將多個 CSS 文件編譯為一個文件

HTML 語法

用兩個空格來代替制表符(tab) -- 這是唯一能保證在所有環(huán)境下獲得一致展現(xiàn)的方法。

在屬性上,使用雙引號,不要使用單引號。

不要在自動閉合標(biāo)簽結(jié)尾處使用斜線 - HTML5 規(guī)范 指出他們是可選的。

不要忽略可選的關(guān)閉標(biāo)簽(例如, 和 )。

嵌套的節(jié)點(diǎn)應(yīng)該縮進(jìn)(四個空格)。

字符編碼

通過明確聲明字符編碼,能夠確保瀏覽器快速并容易的判斷頁面內(nèi)容的渲染方式。這樣做的好處是,可以避免在 HTML 中使用字符實體標(biāo)記(character entity),從而全部與文檔編碼一致(一般采用 UTF-8 編碼)。

引入 CSS 和 JavaScript

根據(jù) HTML5 規(guī)范, 通常在引入 CSS 和 JavaScript 時不需要指明 type,因為 text/css 和 text/javascript 分別是他們的默認(rèn)值。

屬性順序

HTML 屬性應(yīng)該按照特定的順序出現(xiàn)以保證易讀性。

class

id

name

data-*

src, for, type, href, value , max-length, max, min, pattern

placeholder, title, alt

aria-*, role

required, readonly, disabled

Classes 是為高可復(fù)用組件設(shè)計的,理論上他們應(yīng)處在第一位。Ids 更加具體而且應(yīng)該盡量少使用(例如, 頁內(nèi)書簽),所以他們處在第二位。

不要用JavaScript 生成標(biāo)簽

在 JavaScript 文件中生成標(biāo)簽讓內(nèi)容變得更難查找,更難編輯,性能更差。應(yīng)該盡量避免這種情況的出現(xiàn)。

示例代碼


  
    
    
    
    
  
  
    
      Example link
    
    
    ...
    
    
    
  



文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/50258.html

相關(guān)文章

  • 使用ESLint+Prettier來統(tǒng)一前端代碼風(fēng)格

    摘要:但是關(guān)于代碼風(fēng)格,我們很難區(qū)分誰對誰錯,不同的人有不同偏好,唯有強(qiáng)制要求才能規(guī)避爭論。所以,團(tuán)隊關(guān)于代碼風(fēng)格必須遵循兩個基本原則少數(shù)服從多數(shù)用工具統(tǒng)一風(fēng)格。本文將介紹,如何使用來統(tǒng)一我們的前端代碼風(fēng)格。 加分號還是不加分號?tab還是空格?你還在為代碼風(fēng)格與同事爭論得面紅耳赤嗎? 正文之前,先看個段子放松一下: 去死吧!你這個異教徒! 想起自己剛?cè)胄械臅r候,從svn上把代碼checko...

    Corwien 評論0 收藏0
  • 前端代碼風(fēng)格自動化系列(四)之Prettier

    摘要:這里有個官網(wǎng)的例子格式化之后讓我們專注于業(yè)務(wù)邏輯,無需再糾結(jié)代碼風(fēng)格,配合其它工具,實現(xiàn)了代碼提交到倉庫前,統(tǒng)一格式化。 Prettier是一個支持多語言的代碼格式工具,如常用的:js、jsx、Vue、Flow、Ts、HTML、CSS等,非常全面,將代碼解析為AST,然后重新組裝,目的是最終輸出風(fēng)格統(tǒng)一的代碼,對比eslint對error的fix要強(qiáng)一些,如最大長度的改動,eslint...

    wangjuntytl 評論0 收藏0
  • 前端代碼風(fēng)格自動化系列(一)之Husky

    摘要:代碼風(fēng)格和性格一樣,每個程序員都有自己的特點(diǎn),但對于大家協(xié)同開發(fā)的項目,還是需要力求代碼風(fēng)格的一致性,以減少,方便互相修改,短時間內(nèi)能上手,在這條路上誕生了許許多多的工具。本系列主要介紹目前主流的前端代碼格式化的工具。 代碼風(fēng)格和性格一樣,每個程序員都有自己的特點(diǎn),但對于大家協(xié)同開發(fā)的項目,還是需要力求代碼風(fēng)格的一致性,以減少Bug,方便互相修改,短時間內(nèi)能上手,在這條路上誕生了許許多...

    EdwardUp 評論0 收藏0
  • # 前端進(jìn)階--1.為什么要制定開發(fā)規(guī)范?

    摘要:使用代替可以使用工具代替結(jié)語我們應(yīng)該根據(jù)公司情況業(yè)務(wù)場景和團(tuán)隊具體情況來制定適合自己的開發(fā)規(guī)范,開發(fā)規(guī)范不需要最好,也沒有最好的開發(fā)規(guī)范,只有適合自己的。后期我將和大家分享如何制定開發(fā)規(guī)范。 0 為什么要有規(guī)范? 與性能無關(guān) 與功能無關(guān) 與效果無關(guān) 與能力無關(guān) 與工期無關(guān) 但是,規(guī)范必不可少 與效率相關(guān)(開發(fā)、迭代和維護(hù),重點(diǎn)提升維護(hù)及迭代效率) 與團(tuán)隊相關(guān)(減少團(tuán)隊之間的不一致...

    TerryCai 評論0 收藏0
  • 前端代碼風(fēng)格自動化系列(五)之共同出擊

    摘要:我們在前面的四篇中介紹了這些工具,可以完成以最小的代價在提交到遠(yuǎn)程倉庫前,格式化為統(tǒng)一風(fēng)格的代碼,大家都很熟悉這里就不列舉了。下面舉一個配置。這里對于項目里分別做了提交前格式化操作,對于提交規(guī)范做了校驗。 我們在前面的四篇中介紹了husky、commitlint、lint-staged、prettier這些工具,可以完成以最小的代價在Git提交到遠(yuǎn)程倉庫前,格式化為統(tǒng)一風(fēng)格的代碼,es...

    pumpkin9 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<