از زمان ارائهی نگارش 72 مرورگر chrome، قابلیتهای استفاده از ES10، میسر شدهاست. برای اینکه از شماره نگارش مرورگر خود مطلع شوید، کافیست به منوی Help و سپس بر روی گزینهی About Google Chrome کلیک کنید تا شمارهی نسخهی نصبی بر روی سیستم شما مشخص شود:
Symbol.prototype.description: بوسیله ساختن یک متغیر از نوع Symbol میتوانیم توضیحاتی را برای استفادهی خطایابی آینده کد استفاده کنیم:
و اکنون میتوانیم با فراخوانی این تابع بدون نیاز به تابعی برای compare نمودن، مرتب سازی المنتها را انجام دهیم:
تابع ()flat: امکان یکی شدن همه آرایههای زیرمجموعه (sub-array) مجموعه را در یک آرایه جدید فراهم میکند و با استفاده از depth، سطح ادغام آرایه را مشخص میکنیم (عملکرد این تابع بصورت بازگشتی میباشد) و سینتکس استفاده از این تابع بشکل زیر است:
var newArray=Array.flat([depth])
بطور مثال:
var arr1 = [1, 2, [3, 4]]; arr1.flat(); // [1, 2, 3, 4] var arr2 = [1, 2, [3, 4, [5, 6]]]; arr2.flat(); // [1, 2, 3, 4, [5, 6]] var arr3 = [1, 2, [3, 4, [5, 6]]]; arr3.flat(2); // [1, 2, 3, 4, 5, 6]
Array.flatMap : سبب نگاشت المنتها با تابع تعریف شدهی برای این متد میشود. سپس نتیجه در آرایهای جدید برگشت داده میشود. این تابع عملکردی شبیه به انجام تابع map و سپس اجرای تابع ()flat با عمق 1 را دارد:
// Let's say we want to remove all the negative numbers and split the odd numbers into an even number and a 1 let a = [5, 4, -3, 20, 17, -33, -4, 18] // |\ \ x | | \ x x | // [4,1, 4, 20, 16, 1, 18] a.flatMap( (n) => (n < 0) ? [] : (n % 2 == 0) ? [n] : [n-1, 1] ) // expected output: [4, 1, 4, 20, 16, 1, 18]
()Object.fromEntries: یک لیست را که بصورت key-value تعریف شده باشد، به یک آبجکت تبدیل میکند. شیء دریافتی این تابع باید از نوع Arrayو یا mapباشد:
const entries = new Map([ ['foo', 'bar'], ['baz', 42] ]); const obj = Object.fromEntries(entries); console.log(obj); // expected output: Object { foo: "bar", baz: 42 }
()String.trimStart: تابعی برای حذف کردن فضای خالی سمت چپ یک رشته میباشد. نام مستعار دیگر این تابع ()trimStart است:
var greeting = ' Hello world! '; console.log(greeting); // expected output: " Hello world! "; console.log(greeting.trimStart()); // expected output: "Hello world! ";
()String.trimEnd: تابعی برای حذف کردن فضای خالی سمت راست یک رشته میباشد و نام مستعار دیگر این تابع ()trimRight است:
var greeting = ' Hello world! '; console.log(greeting); // expected output: " Hello world! "; console.log(greeting.trimEnd()); // expected output: " Hello world!";
Optional Catch Binding: توسط آن توانایی تعریف بلاک try/catch را بدون نیاز به قرار دادن پارامتری برای catch داریم (گاهی نیاز به استفادهی از متغیری که برای خطای رخ داده شده، ارائه میشود نیست؛ چرا باید آن را تعریف کنیم ؟!)
try { throw new Error('Error'); } catch (error) { // do stuff }
تبدیل میشود به:
try { throw new Error('Error'); } catch { // removed parameter to catch block console.log('Got an error!'); }
const symbol = Symbol('My Symbol!'); console.log(symbol.toString()); // Symbol(My Symbol!) console.log(symbol.description); // My Symbol!
Function.prototype.toString() Revision : پیاده سازی جدیدی از تابع ()toString میباشد. در صورتیکه توسط یک تابع فراخوانی شود کد آن را برگشت میدهد:
// User-defined function object // This prints "function () { console.log('My Function!'); }" console.log(function () { console.log('My Function!'); }.toString()); // Build-in function object // This prints "function parseInt() { [native code] }" console.log(Number.parseInt.toString()); // Bound function object // This prints "function () { [native code] }" console.log(function () { }.bind(0).toString()); // Built-in callable function object // This prints "function Symbol() { [native code] }" console.log(Symbol.toString()); // Dynamically generated function object #1 // This prints "function anonymous() {}" (using V8 engine) console.log(Function().toString()); // Dynamically generated function object #2 // This prints the followng (using V8 engine): // function () { return __generator(this, function (_a) { // return [2 /*return*/]; // }); } console.log(function* () { }.toString()); // This throws a TypeError: "Function.prototype.toString requires that 'this' be a Function" Function.prototype.toString.call({});
()Array.sort: مرتب کردن عناصر یک آرایه را انجام میدهد. پیشتر برای مرتب سازی یک آرایه، کدی را مانند زیر داشتیم:
var numbers = [4, 2, 5, 1, 3]; numbers.sort(function(a, b) { return a - b; }); console.log(numbers); // [1, 2, 3, 4, 5] ES2015یا در let numbers = [4, 2, 5, 1, 3]; numbers.sort((a, b) => a - b); console.log(numbers); // [1, 2, 3, 4, 5]
var months = ['March', 'Jan', 'Feb', 'Dec']; months.sort(); console.log(months); // expected output: Array ["Dec", "Feb", "Jan", "March"] var array1 = [1, 30, 4, 21, 100000]; array1.sort(); console.log(array1); // expected output: Array [1, 100000, 21, 30, 4]