The 2021 proposal adds features to ECMAScript that are described in the following table
String.protype.replaceAll
Before ES2021, to replace all specified characters in a string, we can do this:
const str = "a+b+c+";
const newStr = str.replace(/\+/g."🤣");
console.log(newStr); / / a 🤣 🤣 🤣 c b
// Split the string using split, join
const queryString = "q=query+string+parameters";
const withSpaces = queryString.split("+").join("");
Copy the code
Now that we have a more concise approach, ES2021 proposes the replaceAll method and mounts it on the String prototype, which can be used as follows:
const str = "a+b+c+";
const newStr = str.replaceAll("+"."🤣");
console.log(newStr); / / a 🤣 🤣 🤣 c b
const queryString = "q=query+string+parameters";
const withSpaces = queryString.replaceAll("+"."");
Copy the code
Promise.any
There are four main methods in Promise.
name | Description | |
---|---|---|
Promise.allSettled |
1. Wait until all instances return results, no matter whetherfulfilled orrejected , the instance will end2. Sometimes, we don’t care about the result of asynchronous requests, only care about whether all requests end |
Internet ES2020 ✅ |
Promise.all |
1. If any promise fails, the failed promise is returned. 2. When all asynchronous operations are successful, the promise is returned as an array |
Internet ES2015 ✅ |
Promise.race |
Whenever the state of any promise changes (whether it succeeds or fails), that promise is returned | Internet ES2015 ✅ |
Promise.any |
1. If any promise succeeds, the successful promise is returned. 2. If all promises fail/reject, return a failed promise |
Internet ES2021 ✅ |
Let’s look at a code example for promise.any
// demo-1
Promise.any([
fetch("https://v8.dev/").then(() = > "home"),
fetch("https://v8.dev/blog").then(() = > "blog"),
fetch("https://v8.dev/docs").then(() = > "docs"),
])
.then((first) = > {
// Any of the promises was fulfilled.
console.log(first);
/ / to 'home'
})
.catch((error) = > {
// All of the promises were rejected.
console.log(error);
});
// demo-2
const pErr = new Promise((resolve, reject) = > {
reject("Always fail.");
});
const pSlow = new Promise((resolve, reject) = > {
setTimeout(resolve, 500."Finished");
});
const pFast = new Promise((resolve, reject) = > {
setTimeout(resolve, 100."Soon.");
});
// 使用 .then .catch
Promise.any([pErr, pSlow, pFast])
.then((value) = > {
// Return the first successful promise: pFast-" finish soon"
console.log(value);
})
.catch((err) = > {
// Triggers when all promises fail
});
// demo-3
// Use the top-level -await
try {
const first = await Promise.any(promises); // Any promise is returned successfully.
console.log(first);
} catch (error) {
// All of his promises failed
console.log(error);
}
Copy the code
WeakRef
WeakRef proposal mainly contains two new features:
- Can be achieved by
WeakRef
Class to create a weak reference to an object - Can be achieved by
FinalizationRegistry
Class to perform custom methods after an object has been garbage collected
These two new features can be used together or separately, depending on your needs. A WeakRef object contains a weak reference to an object, called a target or reference.
Weak references to an object allow it to be collected by the garbage collection mechanism without any other references.
WeakRef is used to cache and map large objects. WeakRef is used when you want an object to be garbage collected in time without being referenced elsewhere.
function toogle(element) {
const weakElement = new WeakRef(element);
let intervalId = null;
function toggle() {
const el = weakElement.deref();
if(! el) {return clearInterval(intervalId);
}
const decoration = weakElement.style.textDecoration;
const style = decoration === "none" ? "underline" : "none";
decoration = style;
}
intervalId = setInterval(toggle, 1000);
}
const element = document.getElementById("link");
toogle(element);
setTimeout(() = > element.remove(), 10000);
Copy the code
FinalizationRegistry receives a registry callback function that can be used to register an event listener for a specified object. When the object is garbage collected, the monitored event will be triggered, as follows. First, create a registry:
const registry = new FinalizationRegistry((heldValue) = > {
/ /...
});
Copy the code
We can then register a specified object, and we can also pass some parameters to the registry callback:
registry.register(theObject, "some value");
Copy the code
Detailed content Reference
- How to implement JS real weak reference?
Logical assignment operator
The motivation reason proposed is to simplify the judgment assignment statement
- Default values for function arguments
- The data obtained from the back end cannot be determined to be valid, so you need to determine the reassignment
/ / bad 👴
function example(a) {
// Default `a` to "foo"
if(! a) { a ="foo"; }}function example(opts) {
// Ok, but could trigger setter.
opts.foo = opts.foo ?? "bar";
// No setter, but 'feels wrong' to write.
opts.baz ?? (opts.baz = "qux");
}
Copy the code
/ / better 👶
function example(opts) {
// Setters are not needlessly called.opts.foo ?? ="bar";
// No repetition of `opts.baz`.opts.baz ?? ="qux";
}
// Default parameter values
function example(opts = { foo: "foo", baz: "baz" }) {
return opts;
}
Copy the code
See TS39-proposal-logical-assignment for more information
The logical assignment operator combines a logical operator and an assignment expression. There are two kinds of logical assignment operators:
- Or equal to (
| | =
) - And is equal to (
&& =
) ?? =
| | =
const giveKey = () = > {
return "somekey";
};
let userDetails = { name: "chika".age: 5.room: 10.key: "" };
// userDetails.key = userDetails.key || giveKey();
userDetails.key ||= giveKey();
console.log(userDetails.key);
//output : somekey
Copy the code
&& =
const deleteKey = () = > {
return "";
};
let userDetails = { name: "chika".age: 5.room: 10.key: "990000" };
// userDetails.key = userDetails.key && deleteKey();
userDetails.key &&= deleteKey();
console.log(userDetails.key);
//output : ""
Copy the code
?? = Empty assignment operator
?? = is also known as the empty assignment operator, related to the non-airlift operator above. Look at the connection:
var x = null;
var y = 5;
// x = x ?? y;
console.log((x ?? = y));/ / = > 5
Copy the code
This assignment operator is assigned only if the value is null or undefined. The example above emphasizes that this operator is essentially a syntactic sugar for empty assignments (similar syntactic sugar: a = a + b can be written as a += b).
Next, let’s look at the difference between this operator and the default argument (which is a new syntax introduced in ES6 that sets a default value only if the function argument is undefined) :
function gameSettingsWithNullish(options) { options.gameSpeed ?? =1; options.gameDiff ?? ="easy";
return options;
}
function gameSettingsWithDefaultParams(gameSpeed = 1, gameDiff = "easy") {
return { gameSpeed, gameDiff };
}
gameSettingsWithNullish({ gameSpeed: null.gameDiff: null }); // => {gameSpeed: 1, gameDiff: 'easy'}
gameSettingsWithDefaultParams(undefined.null); // => {gameSpeed: 1, gameDiff: null}
Copy the code
There is a notable difference in the way the above functions handle nulls. The default argument will override the default with an empty argument (null here, only undefined), and the empty assignment operator will not.
Default arguments and empty assignments do not override undefined values.
const getKey = () = > {
return "somekey";
};
let userDetails = { name: "chika".age: 5.room: 10}; userDetails.key ?? = getKey();console.log(userDetails.key);
//output : "somekey"
Copy the code
Number separator
Put forward the reasons:
This feature allows developers to make their numeric text more readable by creating visual separation between groups of numbers.
Large numeric text is difficult for the human eye to parse quickly, especially if the number repeats for a long time. This compromises the ability to get the correct value/order of magnitude.
Such as
1000000000; // Is this a billion? a hundred millions? Ten millions?
101475938.38; // what scale is this? what power of 10?
Copy the code
Therefore, you can use the underscore (_, U + 005F) as the delimiter. Helps improve readability of numeric literals (integer and floating point) (in JS, floating point anyway)
1 _000_000_000; / / one billion
101 _475_938. 38; / / one hundred million
const amount = 12345 _00; / / 1234500
const amount = 123 _4500; / / 1234500
const amount = 1 _234_500; / / 1234500
0.000 _001; // One part per million
1e10_000; / / 10 ^ 10000
//
const binary_literals = 0b1010_0001_1000_0101;
const hex_literals = 0xa0_b0_c0;
//
const bigInt_literals = 1_000_000_000_000n;
//
const octal_literal = 0o1234_5670;
Copy the code
The last
The article is shallow and humble, welcome everyone to see the comment area to leave your opinion!
Feel the harvest of students welcome to like, follow a wave!
The articles
- The most complete ECMAScript guide
- ECMAScript ES2015-ES6
- ECMAScript ES2016-ES7
- ECMAScript ES2017-ES8
- ECMAScript ES2018-ES9
- ECMAScript ES2019-ES10
- ECMAScript ES2021-ES11
- ECMAScript ES2020-ES12
- ECMAScript ES2022-ES13