1塊級作用域
ES5只有全局和函數(shù)作用域。
let和const大溜。線程安全。
塊級作用域估脆,不能重復(fù)聲明钦奋。
長遠來看,JavaScript可能會有多線程的實現(xiàn)(比如Intel的River Trail那一類的項目)疙赠,這時let表示的變量付材,只應(yīng)出現(xiàn)在單線程運行的代碼中,不能是多線程共享的圃阳,這樣有利于保證線程安全厌衔。
2字符串
靜態(tài)字符串一律使用單引號或反引號,不使用雙引號捍岳。動態(tài)字符串使用反引號富寿。
var a='';或者var a=``;
3結(jié)構(gòu)賦值
const arr = [1, 2, 3, 4];
const [first, second] = arr;
4對象
單行定義的對象,最后一個成員不以逗號結(jié)尾锣夹。多行定義的對象页徐,最后一個成員以逗號結(jié)尾。
const a = { k1: v1, k2: v2 };
const b = {
k1: v1,
k2: v2,
};
5數(shù)組
拷貝數(shù)組:const itemsCopy = [...items];
轉(zhuǎn)為數(shù)組:使用Array.from方法银萍,將類似數(shù)組的對象轉(zhuǎn)為數(shù)組变勇。
const foo = document.querySelectorAll('.foo');const nodes = Array.from(foo);
6函數(shù)
簡單的、單行的砖顷、不會復(fù)用的函數(shù)贰锁,建議采用箭頭函數(shù)。
例如:立即執(zhí)行的匿名函數(shù)
(() => { console.log('Welcome to the Internet.');})();
箭頭函數(shù)取代Function.prototype.bind滤蝠,不應(yīng)再用self/_this/that綁定 this豌熄。
const boundMethod = (...params) => method.apply(this, params);
arguments是一個類似數(shù)組的對象,而rest運算符可以提供一個真正的數(shù)組物咳。
7map結(jié)構(gòu)
注意區(qū)分Object和Map锣险,只有模擬現(xiàn)實世界的實體對象時,才使用Object览闰。如果只是需要key: value的數(shù)據(jù)結(jié)構(gòu)芯肤,使用Map結(jié)構(gòu)。因為Map有內(nèi)建的遍歷機制压鉴。
8class
總是用Class崖咨,取代需要prototype的操作。因為Class的寫法更簡潔油吭,更易于理解击蹲。
// goodclass Queue { constructor(contents = []) { this._queue = [...contents]; } pop() { const value = this._queue[0]; this._queue.splice(0, 1); return value; }}
使用extends實現(xiàn)繼承署拟,因為這樣更簡單,不會有破壞instanceof運算的危險歌豺。
class PeekableQueue extends Queue { peek() { return this._queue[0]; }}
9模塊
//引入
首先推穷,Module語法是JavaScript模塊的標準寫法,堅持使用這種寫法类咧。使用import取代require馒铃。
import myObject from './importModule';
import { func1, func2 } from 'moduleA';
//暴露
使用export取代module.exports。
// ES6的寫法import React from 'react';const Breadcrumbs = React.createClass({ render() { return <nav />; }});export default Breadcrumbs
如果模塊只有一個輸出值痕惋,就使用export default区宇,如果模塊有多個輸出值,就不使用export default值戳,不要export default與普通的export同時使用萧锉。
如果模塊默認輸出一個函數(shù),函數(shù)名的首字母應(yīng)該小寫述寡。
如果模塊默認輸出一個對象,對象名的首字母應(yīng)該大寫叶洞。