JS-ES6

15年發(fā)布的 ES6


新增的 數(shù)組方法

// 判定 目標(biāo)數(shù)組中 是否至少有一個(gè)元素滿足 指定條件 --- 返回布爾值
// 數(shù)組.some(function(參1,參2,參3)

var arr = [70, 27, 67, 89]
var bool = arr.some(function (v, i, a) {
    // 本質(zhì)為封裝的循環(huán)遍歷函數(shù)
    console.log(v); // 當(dāng)前遍歷的值
    console.log(i); // 當(dāng)前遍歷的值的下標(biāo) --- 可選參
    console.log(a); // 當(dāng)前遍歷的目標(biāo)數(shù)組 --- 可選參
    return v > 90 // 判斷條件
})
console.log(bool); // false    沒有元素滿足條件
// 判定 目標(biāo)數(shù)組中 是否所有元素 都滿足 指定條件 --- 返回布爾值
// 數(shù)組.every(function(參1,參2,參3)

var arr = [70, 27, 67, 89]
var bool = arr.every(function (v, i, a) {
    return v > 60 // 判斷條件
})
console.log(bool); // false    27不滿足條件 提前結(jié)束
// 判定 目標(biāo)數(shù)組中 第一個(gè) 滿足條件的值 --- 返回目標(biāo)值 否則返回undefined
// 數(shù)組.find(function(參1,參2,參3)

var arr = [70, 27, 67, 89]
var bool = arr.find(function (v, i, a) {
    return v < 60 // 判斷條件
})
console.log(bool); // 27
// 判定 目標(biāo)數(shù)組中 第一個(gè) 滿足條件的值 的下標(biāo) --- 返回目標(biāo)值的下標(biāo) 否則返回-1
// 數(shù)組.findIndex(function(參1,參2,參3)

var arr = [70, 27, 67, 89]
var bool = arr.findIndex(function (v, i, a) {
    return v < 60 // 判斷條件
})
console.log(bool); // 1

新增的 定義變量關(guān)鍵字

let
對(duì)比var 區(qū)別:
1. let定義的變量 沒有 預(yù)解析

console.log(a);
let a = 10

預(yù)解析案例-圖示

2. let定義的全局變量 不存在于window中

let a = 10
var b = 5
console.log(window);

全局變量檢測(cè)-圖示

3. let碰到 大括號(hào) 時(shí) 會(huì)產(chǎn)生獨(dú)立的作用域 --- 塊級(jí)作用域

if (true) {
    var a = 10
}
if (true) {
    let b = 5
}
console.log(a);
console.log(b);

let作用域測(cè)試-圖示

常用場(chǎng)景:解決循環(huán)中的異步操作調(diào)用變量問題

window.onclick = () => {
    for (let i = 1; i <= 3; i++) {
        setInterval(function () {
            console.log(i);
        }, 1000)
    }
}
let解決異步問題-圖示

4. 不允許對(duì) 同一變量 重復(fù)定義

let a = 10
let a = 5
console.log(a);

let重復(fù)定義測(cè)試-圖示

--------------------------------------------------
const
對(duì)比var 區(qū)別 --- 基本同let
對(duì)比let 區(qū)別:
定義的值為常量 --- 不能改變

const a = 5;
a = 10
console.log(a);
改變const常量測(cè)試-圖示

新增的 函數(shù)定義方式 --- 箭頭函數(shù)

// 1. 只針對(duì) 匿名函數(shù) 的簡(jiǎn)寫
// 2. 省略關(guān)鍵字function 小括號(hào)()后添加箭頭=>
var a = () => {console.log(213);}
a()

// 3. 只有一個(gè)形參時(shí) 小括號(hào)可省略
var a = i => {console.log(i);}
a(213)

// 4. 當(dāng)大括號(hào)內(nèi)只有一行代碼時(shí) 大括號(hào)可省略 若代碼只有return 則省略大括號(hào)時(shí) return關(guān)鍵字一定要一起省略
var a = i => i
console.log(a(213));

新增的 字符串方法

var str = 'http://www.baidu.com'

// 1. 字符串是否以某子串 開頭 --- 返回布爾值
// 字符串.startsWith('檢測(cè)子串')
console.log(str.startsWith('http'));

// 2. 字符串是否以某子串 結(jié)尾 --- 返回布爾值
// 字符串.endsWith('檢測(cè)子串')
console.log(str.endsWith('.com'));

// 3. 字符串或數(shù)組 是否 包含 某個(gè)子串或值 --- 返回布爾值
// 字符串|數(shù)組.includes('檢測(cè)子串|值')
var arr = ['ab', 'bb', 'cd']

console.log(str.includes('baidu'));
console.log(arr.includes('bb'));

函數(shù)默認(rèn)值

允許賦予形參默認(rèn)值

// 有實(shí)參傳入時(shí) 實(shí)參覆蓋默認(rèn)值
// 無(wú)實(shí)參傳入時(shí) 使用默認(rèn)值
function add(a, b = 2) {
    return a + b;
}
console.log(add(5, 1)); // 6

// 帶默認(rèn)值的形參變可選項(xiàng)
console.log(add(5)); // 7

// 帶默認(rèn)值的形參只能放在其他形參后面

模板字符串

// 反引號(hào) ``
// 1. 字符串可以換行書寫 且保留換行符和空格
var str1 = `
 1 2 3
4  5  6
`
console.log(str1);

// 2. 字符串中可以直接使用 美元符+大括號(hào) 識(shí)別變量 不用再拼接字符串 且不能拼接字符串
var a = 213
var str2 = `abc${a}def`
console.log(str2);
模板字符串功能展示-圖示

解構(gòu)賦值

本質(zhì):一種快速賦值的方法
數(shù)組解構(gòu)

var arr = [1, 2, 3]
// 1.1 數(shù)組解構(gòu)
// 通過中括號(hào)裝載變量的形式 對(duì)目標(biāo)數(shù)組中"對(duì)應(yīng)下標(biāo)"的數(shù)據(jù)進(jìn)行

var [a, b, c] = arr
console.log(a, b, c); // 1 2 3

var [d, e] = arr
console.log(d, e); // 1 2

var [f, _, g] = arr
console.log(f, g); // 1 3
// 可以使用下劃線作為無(wú)意義變量 接受不需要的數(shù)據(jù) 進(jìn)行跳過

var [h, i, j, k] = arr
console.log(h, i, j, k); // 1 2 3 undefined
var brr = [1, [2, 3], 4]
// 1.2 數(shù)組的多重解構(gòu)

var [a, b, c] = brr
console.log(a, b, c); // 1 [2,3] 4

var [d, [_, e]] = brr
console.log(d, e); // 1 3
// 通過嵌套中括號(hào)來(lái)提取多重?cái)?shù)組中的數(shù)據(jù)
// 1.3 延展:交換兩個(gè)變量的值

var a = 5
var b = 10
console.log(a, b); // 5 10

var [b, a] = [a, b]
console.log(a, b); // 10 5

對(duì)象解構(gòu)

// 2.1 對(duì)象解構(gòu)

var date = {
    year: 2022,
    month: 3,
    day: 29,
}
var {month,day} = date
// 定義的變量名需要跟對(duì)象中的鍵名保持一致
console.log(month,day); // 3 29

// 解構(gòu)對(duì)象并取別名
var {month: m,day: d} = date
// 可以在定義時(shí)通過冒號(hào)連接原鍵名的新變量名
console.log(m, d); // 3 29
console.log(month, day); // 報(bào)錯(cuò)
// 改名后 原鍵名的變量無(wú)法再輸出
// 2.2 對(duì)象的多重解構(gòu)

var date = {
    year: 2022,
    month: 3,
    day: 29,
    time:{
        hour:17,
        min:30
    }
}
var {time:{hour}} = date
// 先提取外層鍵名 通過冒號(hào)連接大括號(hào) 再填寫下一層需要提取的鍵名
console.log(hour); // 17

展開 / 合并運(yùn)算符 (點(diǎn)點(diǎn)點(diǎn)運(yùn)算符)

// 1. 展開運(yùn)算符
// 1.1 展開數(shù)組
var arr = [1, 2, 3, 4]

console.log(arr); // [1,2,3,4]
console.log(Object.prototype.toString.call(arr)); // [object Array]

console.log(...arr); // 1 2 3 4
// 數(shù)組被展開成數(shù)字
console.log(Object.prototype.toString.call(...arr)); // [object Number]

// 1.2 展開對(duì)象
var time = {
    month: 3,
    day: 29,
}
var date = {
    year: 2022,
    ...time
}
console.log(date); // {year: 2022, month: 3, day: 29}
// 對(duì)象time被展開成多個(gè)鍵值對(duì)
// 2. 合并運(yùn)算符用法

var arr
function fn(...a) {
    arr = a
}
fn(6, 7, 8, 9)
// 該組數(shù)據(jù)在傳入時(shí) 被合并為數(shù)組
console.log(arr); // [6,7,8,9]
console.log(Object.prototype.toString.call(arr)); // [object Array]

對(duì)象的簡(jiǎn)寫

// 允許對(duì)象外的變量 作為同名鍵值對(duì) 填充進(jìn)對(duì)象

var str = 'abc';
var arr = [1, 2, 3];
var fn = () => 0

var obj = {
    str,
    arr,
    fn
}
console.log(obj); // {str: 'abc', arr: Array(3), fn: ?}

新增的 檢測(cè)數(shù)據(jù)類型 的方法

// Object.prototype.toString.call()
// 可用于引用類型數(shù)據(jù)的檢測(cè) 可返回更加明確的數(shù)據(jù)類型

console.log( Object.prototype.toString.call([]) ); // [object Array]
console.log( Object.prototype.toString.call({}) ); // [object Object]
console.log( Object.prototype.toString.call(Math) ); // [object Math]
console.log( Object.prototype.toString.call(new Date()) ); // [object Date]
console.log(Object.prototype.toString.call(function(){})); // [object Function]
console.log(Object.prototype.toString.call(/^abc$/)); // [object RegExp]

上下文調(diào)用模式 --- 借用模式 --- 借用函數(shù)

// 函數(shù).call(this的新指向,實(shí)參1,實(shí)參2...)
// 1.1 調(diào)用函數(shù)
function fn() {console.log(123);}
fn.call() // 等效于fn()

// 1.2.1 改變函數(shù)this的指向
function fn() {console.log(this);}
var obj = {year : 2022}
fn()
fn.call(obj)

// 1.2.2 只調(diào)用函數(shù) 但是不改變函數(shù)this的指向
function fn(a, b) {console.log(a + b);}
fn.call(null, 10, 5) // 15
// call方法中 第一個(gè)參數(shù)為原函數(shù)this的新指向 填null即不改變 后續(xù)實(shí)參可以正常傳參
// 但null不能省略 且只能在第一位
1.2 call方法改變函數(shù)this-圖示
// 函數(shù).apply(this的新指向,由實(shí)參組成的數(shù)組)
// 用法與call大致相同
// call可傳入多個(gè)實(shí)參
// apply一般只有兩個(gè)參數(shù) 第二個(gè)參數(shù)為數(shù)組

function fn(a, b) {console.log(a + b);}
fn.apply(null, [10, 5]) // 15
// 函數(shù).bind(this的新指向)
// 復(fù)制函數(shù) 且改變新函數(shù)this的指向

function fn() {console.log(123);}
var fun = fn.bind()
fun() // 123

借用函數(shù)

原理:利用某方法的 原型 調(diào)用該方法 再用call改變方法的 this的指向

// 場(chǎng)景1 偽數(shù)組轉(zhuǎn)數(shù)組
var lis = document.querySelectorAll('li')
console.log(lis); // NodeList(3) [li, li, li]
console.log(Object.prototype.toString.call(lis)); // [object NodeList]

console.log([].slice.call(lis, 0)); // [li, li, li]
// 過程:調(diào)用本屬于數(shù)組的slice方法 將slice的this指向改為變量lis 再傳入?yún)?shù)0 從下標(biāo)0開始截取 返回新數(shù)組
console.log(Object.prototype.toString.call([].slice.call(lis, 0))); // [object Array]

偽數(shù)組
可以遍歷 但不能使用數(shù)組方法

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末袱瓮,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子搂抒,更是在濱河造成了極大的恐慌虽风,老刑警劉巖枣氧,帶你破解...
    沈念sama閱讀 219,490評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件月褥,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡森缠,警方通過查閱死者的電腦和手機(jī)深滚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門奕谭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人痴荐,你說(shuō)我怎么就攤上這事血柳。” “怎么了生兆?”我有些...
    開封第一講書人閱讀 165,830評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵难捌,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我鸦难,道長(zhǎng)根吁,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,957評(píng)論 1 295
  • 正文 為了忘掉前任合蔽,我火速辦了婚禮击敌,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘拴事。我一直安慰自己沃斤,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評(píng)論 6 393
  • 文/花漫 我一把揭開白布刃宵。 她就那樣靜靜地躺著衡瓶,像睡著了一般。 火紅的嫁衣襯著肌膚如雪牲证。 梳的紋絲不亂的頭發(fā)上哮针,一...
    開封第一講書人閱讀 51,754評(píng)論 1 307
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼十厢。 笑死等太,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的寿烟。 我是一名探鬼主播澈驼,決...
    沈念sama閱讀 40,464評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼筛武!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起挎塌,我...
    開封第一講書人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤徘六,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后榴都,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體待锈,經(jīng)...
    沈念sama閱讀 45,847評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評(píng)論 3 338
  • 正文 我和宋清朗相戀三年嘴高,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了竿音。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,137評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡拴驮,死狀恐怖春瞬,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情套啤,我是刑警寧澤宽气,帶...
    沈念sama閱讀 35,819評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站潜沦,受9級(jí)特大地震影響萄涯,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜唆鸡,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評(píng)論 3 331
  • 文/蒙蒙 一涝影、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧争占,春花似錦燃逻、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至刻蟹,卻和暖如春逗旁,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工片效, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留红伦,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,409評(píng)論 3 373
  • 正文 我出身青樓淀衣,卻偏偏與公主長(zhǎng)得像昙读,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子膨桥,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • let/const let塊級(jí)作用域:一種普遍存在于各個(gè)語(yǔ)言中的作用域范圍蛮浑; 在一個(gè)大括號(hào)中用let聲明的變量在外...
    壹枕星河閱讀 207評(píng)論 0 0
  • JS 延遲加載js defer 異步并行下載,在document解析完后執(zhí)行只嚣,多腳本按順序執(zhí)行沮稚,async 異步并...
    jasonyang2019閱讀 352評(píng)論 0 0
  • 本文為原創(chuàng),作者為Mozilla Web册舞、Jason Orendorff蕴掏,譯者為L(zhǎng)enville。未經(jīng)許可调鲸,拒絕任...
    尾尾閱讀 4,986評(píng)論 1 20
  • 實(shí)習(xí)的時(shí)候?qū)懙膶W(xué)習(xí)筆記 如有錯(cuò)誤請(qǐng)各位大佬直接留言批判盛杰,防止錯(cuò)誤的信息會(huì)誤導(dǎo)他人! ---------------...
    ci魚丸粗面閱讀 520評(píng)論 0 0
  • ES6發(fā)布于2015年藐石,增加了重要的新特性(包括類和模塊語(yǔ)法)即供。這些新特性把javaScript從一門腳本語(yǔ)言轉(zhuǎn)變...
    卓?jī)簂over閱讀 1,912評(píng)論 1 6