es6 常用方法

来源:https://www.cnblogs.com/Byme/archive/2018/09/05/9592809.html
-Advertisement-
Play Games

來自 https://www.cnblogs.com/lhl66/p/9555903.html 侵刪 來自 https://www.cnblogs.com/lhl66/p/8862106.html 侵刪 1. let, const 都是塊級作用域, 其有效範圍僅在代碼塊中。 //es5 if (a ... ...


來自 https://www.cnblogs.com/lhl66/p/9555903.html 侵刪
來自 https://www.cnblogs.com/lhl66/p/8862106.html 侵刪

1.
let,
const 都是塊級作用域, 其有效範圍僅在代碼塊中。
    //es5
if (a == 1) {
    var b = 'xxx';
}
console.log(b); //xxx

//es6
if (a == 1) {
    let b = 'xxx';
}
console.log(b); //undefined
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
const sum = { num1: 1, num2: 2 };
sum.num2 = 6;
console.log(sum); //{num1:1,num2:6}
常量只是指向了對象的指針, 對象本身的內容卻依然可以被修改
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
2. 模板字元串
//es5
$('#mark').append(
    '出售中 <span>' + obj.num + '</span> ' +
    '剩下的, ' + '<span>' + obj.showNum + '</span> 賣完了!');
//es6
//在es6中,內容模板,可以定義在 `` 包起來的字元串中,其中的內容會保持原有格式
//另外可以在字元串中直接使用模板語言進行變數填充,優雅而簡潔
$('#mark').append(`
  出售 <span>${obj.num}</span> 剩下 <span>${obj.showNum}</span>`);
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
3. 字元串遍歷輸出, 補全
for (let item of 'str') {
    console.log(item);
}
//s
//t
//r
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
//參數1:[number] 目標字元串長度
//參數2:[string] 進行補全的字元串
'123'.padStart(5, '0') //00123 - 字元串不足5位,在頭部補充不足長度的目標字元串
'345'.padEnd(5, '0') //34500 - 在尾部進行字元串補全
    -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
    4. 數組擴展
let a = [1, 2];
let b = [2, 3];
let c = [...a, ...b]; //[1, 2, 2, 3] 所有內容合併,但並不會去除重覆
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
Array.of(3, 4, 5) //快速轉換為數組 [3,4,5]
    -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
    .keys() - 獲得數組中所有元素的鍵名( 實際上就是下標索引號)
    .values() - 獲得數組中所有元素的數據
    .entries() - 獲得數組中所有數據的鍵名和數據
for (let i of['x', 'y'].keys()) {
    console.log(i); //0 1
}
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
for (let elem of['x', 'y'].values()) {
    console.log(elem); //x y
}
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
for (let [index, elem] of['x', 'y'].entries()) {
    console.log(index, elem); // 0 "x"    1 "y"
}
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
5. 對象擴展
//直接使用變數/常量的名稱個為對象屬性的名稱
let a = 'abc';
let b = { a }; //{a: 'abc'}
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
判斷對象是否為數組
if (Object.isArray(obj)) {}
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
對象內容合併
Object.keys() - 獲得對象中所有的鍵名, 以數組的形式返回
var obj = { a: 1, b: 2 };
var names = Object.keys(obj); //['a', 'b']
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
Object.values() - 獲得對象中所有的值內容, 以數組的形式返回
var obj = { a: 1, b: 2 };
var values = Object.values(obj); //[1, 2]
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
Object.entries() - 獲得對象中所有的成員數據, 以數組的形式返回, 成員的內容也是數組形式
var obj = { a: 1, b: 2 };
var values = Object.entries(obj); //[['a',1], ['b',2]]
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
解構賦值
let [a, …b] = [1, 2, 3];
//這裡 b 的值為[2,3],這樣可以快速使用剩餘的數據賦值給變數,
let [a, b, c] = [1, 2, 3];
//定義了三個變數,並對應賦了值;如果值的個數與變數名個數不匹配,沒有對應上的變數值為 undefinedlet obj = {a: 1, b: 2};
let { a, b } = obj; //a=1,b=2
使用變數的方式進行結構賦值, 需要嚴格匹配名稱, 數組的模式是嚴格匹配下標
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
6. 模塊化
//app.js
let act = { a: 1, b: 2, c: 3 };
export default act;

//index.js
import act from 'app.js'; //假設 app.js 與index.js 同在一個目錄中
console.log(act.a); //1

//--------------------------------------------------------------------分割
//ES6字元串擴展方法,三個方法都支持第二個參數,表示開始搜索的位置;
let str = 'Hello world!';
console.log(str.includes('o')) // true ----表示是否找到了參數字元串;類似ES5 indexOf()
console.log(str.startsWith('Hello')) // true ----表示參數字元串是否在原字元串的頭部;
console.log(str.endsWith('!')) // true ----表示參數字元串是否在原字元串的尾部;
    //ES6字元串擴展方法----模板字元串
let hello = '你好';
let str1 = `${hello},這節課學習字元串模板`;
console.log(str1); //你好,這節課學習字元串模板,省去拼接的煩惱;
alert `123`
    // 等同於
alert(123)
    //ES6解構賦值
let res = {
    id: 1,
    status: "OK",
    list: [{
        name: 'bob',
        age: 20
    }]
}
let {
    id,
    status,
    list
} = res;
console.log(id, status, list);
// 1, "OK", [{name: 'bob',age: 20}]
//const 聲明常量 === var a = 1, b = 2, c = 3;or const a = 1;const b = 2;const c = 3;
const [a, b, c] = [1, 2, 3];
console.log(a, 'aaaaa'); //1 "aaaaa"
console.log(b, 'bbbbb'); //2 "bbbbb"
console.log(c, 'ccccc'); //3 "ccccc"
//使用擴展運算符(...)拷貝數組
let test = [1, 2, 3, 4, 5]
let [...test1] = test
test[2] = 5
console.log(test, '原數組') //[1, 2, 5, 4, 5] "原數組"
console.log(test1, '深拷貝的數組') //[1, 2, 3, 4, 5] "深拷貝的數組"
    //不要在模塊輸入中使用通配符。因為這樣可以確保你的模塊之中,有一個預設輸出(export default)。
    // bad
    //import * as myObject from './importModule';
    // good
    //import myObject from './importModule';
    //reset參數---rest參數搭配的變數是一個數組,該變數將多餘的參數放入數組中
function add(...values) {
    let sum = 0;
    for (var val of values) {
        sum += val;
    }
    return sum;
}
console.log(add(2, 5, 3)) // 10
    //箭頭函數
var sum = (num1, num2) => num1 + num2;
// 等同於
var sum = function(num1, num2) {
    return num1 + num2;
};
console.log(sum(1, 4), '求和') //5 "求和"
    //如果只有單個參數
var fun = age => age; //or var fun = (age) => age;
// 等同於
var fun = function(age) {
    return age;
};
console.log(fun(20), '箭頭函數單個參數') //20 "箭頭函數單個參數"
    //擴展運算符加箭頭函數
const sumList = (...num) => num;
console.log(sumList(1, 2, 3, 4, 5), '擴展運算符運用場景一') // [1, 2, 3, 4, 5] "擴展運算符運用場景一"
const getList = (name, ...obj) => [name, obj];
console.log(getList(1, 2, 3, 4, 5), '擴展運算符運用場景二') // [1,[2,3,4,5]] "擴展運算符運用場景二"
    //ES6數組擴展******將一個數組添加到另一個數組的尾部
    // ES5的 寫法
var test2 = [0, 1, 2];
var test3 = [3, 4, 5];
//console.log(test2.push(test3),'push直接跟數組')// 4 "push直接跟數組" push方法的參數不能是數組;
Array.prototype.push.apply(test2, test3);
console.log(test2, '沒用...前') //[0, 1, 2, 3, 4, 5] "沒用...前"
    // ES6 的寫法
let test4 = [0, 1, 2];
let test5 = [3, 4, 5];
test4.push(...test5);
console.log(test4, '使用...後') //[0, 1, 2, 3, 4, 5] "使用...後"
    //ES6將類數組轉為數組的方法;dom類似除了document.getElementById()之外的找到的dom都為類數組;另外有length屬性的;
let toList = {
    '0': 'bob',
    '1': '20',
    '2': 'man',
    length: 3
};
// ES5的寫法
var newArr = [].slice.call(toList);
console.log(newArr, '[].slice.call的方法') //["bob", "20", "man"] "[].slice.call的方法"
    // ES6的寫法
let newArr1 = Array.from(toList);
console.log(newArr1, 'Array.from方法') //["bob", "20", "man"] "Array.from方法"
    //find方法的回調函數可以接受三個參數,依次為當前的值、當前的位置和原數組;如果沒有符合條件的成員,則返回undefined。
let numList = [1, 5, 15, 20, 25];
let newNumList = numList.find((value, index, arr) => {
    return value > 20;
})
console.log(newNumList, '數組find方法') //25 "數組find方法"
    //findIndex方法的用法與find方法非常類似,返回第一個符合條件的數組成員的位置,如果所有成員都不符合條件,則返回-1。
let numLogs = [5, 10, 15, 20];
let newNumLogs = numLogs.findIndex((value, index, arr) => {
    return value > 10
})
console.log(newNumLogs, '數組findIndex方法') //2 "數組findIndex方法"
    //ES6數組的 includes()  第一個參數是否包含一個指定的值,第二個參數表示搜索的起始位置,預設為0;
    //如果第二個參數為負數,則表示倒數的位置,如果這時它大於數組長度(比如第二個參數為-4,但數組長度為3),則會重置為從0開始;
    //沒有該方法之前,我們通常使用數組的indexOf方法,檢查是否包含某個值;
console.log([1, 2, 3].includes(4), 'includes一個參數') //false "includes一個參數"
console.log([1, 2, 3].includes(3, -1), 'includes兩個參數') //true "includes兩個參數"
    //ES6對象的結構和擴展運算符的運用*****...擴展運算符 解構賦值必須是最後一個參數(數組和對象都是一樣) 解構賦值的拷貝是淺拷貝;
let { x, y, ...z } = { x: 1, y: 2, a: 3, b: 4 };
console.log(x, '對象的第一個值'); //1 "對象的第一個值"
console.log(y, '對象的第二個值'); //2 "對象的第二個值"
console.log(z, '對象的第三個值'); //{a: 3, b: 4} "對象的第三個值"
let obj = {
    name: 'bob',
    age: 20
}
let obj1 = {
    sex: 'sex',
    cash: 22
}
let newObj = {...obj, ...obj1 }; //等同於 let newObj = Object.assign({}, obj,obj1);
console.log(newObj, '擴展運算符合併對象') //{name: "bob", age: 20, sex: "sex", cash: 22} "擴展運算符合併對象"
    //ES6 async 函數   await 是順序執行的,Promise.all() 是並行的;
function fun1() {
    console.log('第一') //第一
}

function fun2() {
    console.log('第二') //第二
}

function fun3() {
    console.log('第三') //第三
}
async function testasync() {
    try {
        await fun1()
        await fun2()
        await fun3()
    } catch (error) {
        console.log(error)
    }
}
testasync();
//let [res1, res2, res3] = await Promise.all([fun1(), fun2(),fun3()])
//async 函數中 return 的結果將作為回調的參數;
async function testCallback() {
    return 'this is a test async function'
}
testCallback().then(
        userName => console.log(userName)
    )
    // this is a test async function

 

 

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 安卓開發者官方網站:https://developer.android.google.cn Android Studio下載地址:https://developer.android.google.cn/studio/ ...
  • 譯者按: 做一個有追求的工程師,代碼不是隨便寫的! 原文: "Here’s how you can make better use of JavaScript arrays" 譯者: "Fundebug" 為了保證可讀性,本文采用意譯而非直譯。另外,本文版權歸原作者所有,翻譯僅用於學習。 小編推薦: ...
  • HTML 基本文檔 <!DOCTYPE html>html文件聲明。 charset="UTF-8"文檔編碼聲明。 <meta/>定義關於HTML文檔的元數據,會被瀏覽器解析,主要有三類屬性,name,content,http-equiv。 基本標簽(Basic Tags) 文本格式化(Format ...
  • iOS原生混合RN開發詳解 做過原生iOS開發或者Android開發的同學們肯定也都瞭解Hybrid,有一些Hybrid的開發經驗,目前我們企業開發中運用最廣泛的Hybrid App技術就是原生與H5 hybrid,在早期的時候,可能部分同學也接觸過PhoneGap等hybrid技術,今天我們就簡單 ...
  • 哈哈哈,我又又又回來了,不好意思,最近枸杞喝的比較到位,精力比較旺盛。 現在我們來聊一聊啥是回調地獄,註意是回調地獄啊 不是RB人民最愛拍的那啥地獄啊,來吧,上車吧少年,這是去幼兒園的車 都讓開,我要上高清無碼大圖了啊,青少年註意避讓 ...
  • 一.javaScript(以下簡稱js)的歷史 1992年Nombas開發出C-minus-minus(C--)的嵌入式腳本語言(最初綁定在CEnvi軟體中).後將其改名ScriptEase.(客戶端執行的語言) Netscape(網景)接收Nombas的理念,(Brendan Eich)在其Net ...
  • 參考博文:https://www.cnblogs.com/zhenfei-jiang/p/7065038.html 按照網上查找的資料敲了代碼 出現的問題 : 輸入一個key就執行send方法發送數據給伺服器,還沒輸入完就發送了。 後來換了一種方法 也出現了問題,識別不到回車keycode,隨意按其 ...
  • auto-workflow 用於快速構建各種關係圖的庫,比如流程圖,可視化執行流等 github地址:https://github.com/auto-workflow/AWorkflow 快速開始 npm install aworkflow 或者引用dist文件夾下的產出文件 訪問demo npm ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...