選單
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

JS 教程

JS HOME JS Introduction JS Where To JS Output JS Statements JS Syntax JS Comments JS Variables JS Let JS Const JS Operators JS Arithmetic JS Assignment JS Data Types JS Functions JS Objects JS Object Properties JS Object Methods JS Object Display JS Object Constructors JS Events JS Strings JS String Methods JS String Search JS String Templates JS Numbers JS BigInt JS Number Methods JS Number Properties JS Arrays JS Array Methods JS Array Search JS Array Sort JS Array Iteration JS Array Const JS Dates JS Date Formats JS Date Get Methods JS Date Set Methods JS Math JS Random JS Booleans JS Comparisons JS If Else JS Switch JS Loop For JS Loop For In JS Loop For Of JS Loop While JS Break JS Iterables JS Sets JS Set Methods JS Maps JS Map Methods JS Typeof JS Type Conversion JS Destructuring JS Bitwise JS RegExp JS Precedence JS Errors JS Scope JS Hoisting JS Strict Mode JS this Keyword JS Arrow Function JS Classes JS Modules JS JSON JS Debugging JS Style Guide JS Best Practices JS Mistakes JS Performance JS Reserved Words

JS 版本

JS 版本 JS 2009 (ES5) JS 2015 (ES6) JS 2016 JS 2017 JS 2018 JS 2019 JS 2020 JS 2021 JS 2022 JS 2023 JS 2024 JS IE / Edge JS 歷史

JS 物件

物件定義 物件原型 物件方法 物件屬性 物件 Get / Set 物件保護

JS 函式

函式定義 函式引數 函式呼叫 函式 Call 函式 Apply 函式 Bind 函式閉包

JS 類

類入門 類繼承 類靜態

JS 非同步

JS 回撥 JS 非同步 JS Promises JS Async/Await

JS HTML DOM

DOM 入門 DOM 方法 DOM Document DOM 元素 DOM HTML DOM 表單 DOM CSS DOM 動畫 DOM 事件 DOM 事件監聽器 DOM 導航 DOM 節點 DOM 集合 DOM 節點列表

JS Browser BOM

JS Window JS Screen JS Location JS History JS Navigator JS Popup Alert JS Timing JS Cookies

JS Web APIs

Web API 入門 Web 表單 API Web History API Web Storage API Web Worker API Web Fetch API Web Geolocation API

JS AJAX

AJAX 入門 AJAX XMLHttp AJAX Request AJAX Response AJAX XML 檔案 AJAX PHP AJAX ASP AJAX 資料庫 AJAX 應用 AJAX 示例

JS JSON

JSON 入門 JSON 語法 JSON vs XML JSON 資料型別 JSON 解析 JSON Stringify JSON 物件 JSON 陣列 JSON 伺服器 JSON PHP JSON HTML JSON JSONP

JS vs jQuery

jQuery 選擇器 jQuery HTML jQuery CSS jQuery DOM

JS Graphics

JS Graphics JS Canvas JS Plotly JS Chart.js JS Google Chart JS D3.js

JS 示例

JS 示例 JS HTML DOM JS HTML 輸入 JS HTML 物件 JS HTML 事件 JS 瀏覽器 JS 編輯器 JS 練習 JS 測驗 JS 網站 JS 面試準備 JS Bootcamp JS 證書

JS 參考

JavaScript 物件 HTML DOM 物件


ECMAScript 2019

JavaScript 版本號

舊的 ECMAScript 版本使用數字命名:ES5 和 ES6。

從 2016 年起,版本按年份命名:ES2016、2018、2020……

ES2019 中的新功能


JavaScript 字串 trimStart() 方法

ES2019 向 JavaScript 添加了 String 方法 trimStart()

trimStart() 方法的工作方式類似於 trim(),但只刪除字串開頭的空格。

示例

let text1 = "     Hello World!     ";
let text2 = text1.trimStart();
自己動手試一試 »

JavaScript String trimStart() 自 2020 年 1 月起在所有現代瀏覽器中都得到了支援。

Chrome 66 Edge 79 Firefox 61 Safari 12 Opera 50
2018 年 4 月 2020 年 1 月 2018 年 6 月 2018 年 9 月 2018 年 5 月

JavaScript 字串 trimEnd() 方法

ES2019 向 JavaScript 添加了 String 方法 trimEnd()

trimEnd() 方法類似於 trim(),但僅移除字串末尾的空格。

示例

let text1 = "     Hello World!     ";
let text2 = text1.trimEnd();
自己動手試一試 »

JavaScript String trimEnd() 自 2020 年 1 月起在所有現代瀏覽器中都得到了支援。

Chrome 66 Edge 79 Firefox 61 Safari 12 Opera 50
2018 年 4 月 2020 年 1 月 2018 年 6 月 2018 年 9 月 2018 年 5 月

JavaScript Object fromEntries()

ES2019 向 JavaScript 添加了 Object 方法 fromEntries()

方法 fromEntries() 從可迭代的鍵/值對建立物件。

示例

const fruits = [
["apples", 300],
["pears", 900],
["bananas", 500]
];

const myObj = Object.fromEntries(fruits);
自己動手試一試 »

JavaScript Object fromEntries() 自 2020 年 1 月起在所有現代瀏覽器中都得到了支援。

Chrome 73 Edge 79 Firefox 63 Safari 12.1 Opera 60
2019 年 3 月 2020 年 1 月 2018 年 10 月 2019 年 3 月 2019年4月


可選的 catch 繫結

從 ES2019 開始,如果您不需要 catch 引數,可以省略它:

示例

2019 年之前

try {
// code
} catch (err) {
// code
}

2019 年之後

try {
// code
} catch {
// code
}

可選的 catch 繫結自 2020 年 1 月起在所有現代瀏覽器中都得到了支援。

Chrome 66 Edge 79 Firefox 58 Safari 11.1 Opera 53
2018 年 4 月 2020 年 1 月 2018 年 1 月 2018 年 3 月 2018 年 5 月

JavaScript 陣列 flat() 方法

ES2019 向 JavaScript 添加了 Array flat() 方法。

方法 flat() 透過展平巢狀陣列來建立一個新陣列。

示例

const myArr = [[1,2],[3,4],[5,6]];
const newArr = myArr.flat();
自己動手試一試 »

JavaScript 陣列 flat() 自 2020 年 1 月起在所有現代瀏覽器中均受支援

Chrome 69 Edge 79 Firefox 62 Safari 12 Opera 56
2018 年 9 月 2020 年 1 月 2018 年 9 月 2018 年 9 月 2018 年 9 月

JavaScript Array flatMap()

ES2019 向 JavaScript 添加了 Array flatMap() 方法。

flatMap() 方法首先對映陣列的所有元素,然後透過展平陣列建立一個新陣列。

示例

const myArr = [1, 2, 3, 4, 5, 6];
const newArr = myArr.flatMap(x => [x, x * 10]);
自己動手試一試 »

穩定的 Array sort()

ES2019 **修訂了** Array sort() 方法。

2019 年之前,規範允許使用如 QuickSort 等不穩定排序演算法。

ES2019 之後,瀏覽器必須使用穩定的排序演算法。

當按值對元素進行排序時,元素必須保持與其他具有相同值的元素相對位置。

示例

const myArr = [
  {name:"X00",price:100 },
  {name:"X01",price:100 },
  {name:"X02",price:100 },
  {name:"X03",price:100 },
  {name:"X04",price:110 },
  {name:"X05",price:110 },
  {name:"X06",price:110 },
  {name:"X07",price:110 }
];
自己動手試一試 »

在上面的示例中,當按價格排序時,結果不應出現名稱相對位置不同的情況,例如:

X01 100
X03 100
X00 100
X03 100
X05 110
X04 110
X06 110
X07 110

已修訂的 JSON.stringify()

ES2019 **修訂了** JSON stringify() 方法。

2019 年之前,JSON 無法將用 \u 轉義的字元轉換為字串。

示例

let text = JSON.stringify("\u26D4");
自己動手試一試 »

在 ES2019 之前,使用 JSON.stringify() 處理 UTF-8 程式碼點 (U+D800 到 U+DFFF) 會返回損壞的 Unicode 字元,如 ���。

在此修訂之後,包含 UTF-8 程式碼點的字串可以使用 JSON.stringify() 安全地轉換,並使用 JSON.parse() 恢復到原始狀態。


分隔符符號

行分隔符和段落分隔符符號 (\u2028 和 \u2029) 現在允許在字串字面量中使用。

2019 年之前,這些被視為行終止符,會導致錯誤異常。

示例

// This is valid in ES2019
let text = "\u2028";
自己動手試一試 »

注意

現在,JavaScript 和 JSON 擁有相同的規則。

ES2019 之前

text = JSON.parse('"\u2028"') 解析為 ''。

text = '"\u2028"' 會給出 **語法錯誤**。


已修訂的 Function toString()

ES2019 **修訂了** Function toString() 方法。

方法 toString() 返回一個表示函式原始碼的字串。

從 2019 年起,toString() 必須返回函式的原始碼,包括註釋、空格和語法細節。

2019 年之前,不同的瀏覽器會返回函式的不同變體(例如,不包含註釋和空格)。從 2019 年起,函式應精確返回其編寫時的狀態。

示例

function myFunction(p1, p2) {
  return p1 * p2;
}
自己動手試一試 »

×

聯絡銷售

如果您想將 W3Schools 服務用於教育機構、團隊或企業,請傳送電子郵件給我們
sales@w3schools.com

報告錯誤

如果您想報告錯誤,或想提出建議,請傳送電子郵件給我們
help@w3schools.com

W3Schools 經過最佳化,旨在方便學習和培訓。示例可能經過簡化,以提高閱讀和學習體驗。教程、參考資料和示例會不斷審查,以避免錯誤,但我們無法保證所有內容的完全正確性。使用 W3Schools 即表示您已閱讀並接受我們的使用條款Cookie 和隱私政策

版權所有 1999-2024 Refsnes Data。保留所有權利。W3Schools 由 W3.CSS 提供支援