The ES2019 specification is a minor addition to JavaScript, but it still brings some useful features. This article shows you five new ES2019 features that might make your programming a little easier. These features include trimStart(), trimEnd(), Flat (), flatMap(), object.fromentries (), etc.
TrimStart and trimEnd methods for strings
Both methods can help you remove white space from a given string. The first method, trimStart(), removes all whitespace at the beginning of the string. The second, trimEnd(), removes all whitespace at the end of the string. If you need to remove whitespace from both sides, one way is to use both methods, or use the trim() string method.
'JavaScript'.trimStart()
// Output:
//'JavaScript'
' JavaScript'.trimStart()
// Output:
//'JavaScript'
' JavaScript '.trimStart()
// Output:
//'JavaScript '
'JavaScript '.trimStart()
// Output:
//'JavaScript '
' JavaScript'.trimEnd()
// Output:
//' JavaScript'
' JavaScript '.trimEnd()
// Output:
//' JavaScript'
'JavaScript '.trimEnd()
// Output:
//'JavaScript'
Copy the code
ToString method of the function
Any object has a toString() method, and functions are no exception. This method allows you to print the code for a function that you or someone else wrote. Prior to ES2019, the toString() method removes comments and whitespace. Therefore, the printed version of the function may not be the same as the original code. When ES2019 is released, the toString() method will return the same value as the original, including comments, whitespace, and special characters.
// Before ES2019:
function myFunc/ *is this really a good name? * /) {
/* Now, what to do? * /
}
myFunc.toString()
// Output:
// "function myFunc() {}"
// ES2019:
function myFunc/ *is this really a good name? * /) {
/* Now, what to do? * /
}
myFunc.toString()
// Output:
// "function myFunc /* is this really a good name? * / () {
// /* Now, what to do? * /
// }"
Copy the code
Flat and flatMap methods of arrays
Arrays are a fundamental part of JavaScript, and they can be a pain at times, especially if you’re dealing with multi-dimensional arrays. For example, the deceptively simple event of turning a multidimensional array into a one-dimensional array. The flat() and flatMap() methods ES2019 now provides for arrays can make this easier.
Flat () method
The first one is flat(), which in Chinese means flat or flat. It flattens a multidimensional array into a one-dimensional array. By default, flat() expands only the first layer. If you need to flatten more layers or depths, you can specify a layer or depth value to pass as a parameter. If you’re not sure how many layers, you can also use Infinity, which means how many layers unfold.
// Create an array:
const myArray = ['JavaScript'['C'.'C++'['Assembly'['Bytecode']]]]
// Expand the first layer of the array
let myFlatArray = myArray.flat(1)
console.log(myFlatArray)
// Output:
// [ 'JavaScript', 'C', 'C++', [ 'Assembly', [ 'Bytecode' ] ] ]
// Expand as many layers as possible
let myInfiniteFlatArray = myArray.flat(Infinity)
console.log(myInfiniteFlatArray)
// Output:
// [ 'JavaScript', 'C', 'C++', 'Assembly', 'Bytecode' ]
Copy the code
FlatMap () method
In addition to the flat() method, there is the flatMap() method. You can think of this method as an advanced version of flat(). The difference is that the flatMap() method combines the flat() and map() methods. When you flatten an array, you call a callback function. This allows you to process individual elements inside the original array while flattening. This comes in handy when you want to flatten an array but also modify the contents.
// Create an array:
const myArray = ['One word'.'Two words'.'Three words']
// Delimit the strings in the array with Spaces
// Note: This creates a two-dimensional array
const myMappedWordArray = myArray.map((str) = > str.split(' '))
console.log(myMappedWordArray)
// Output:
// [ [ 'One', 'word' ], [ 'Two', 'words' ], [ 'Three', 'words' ] ]
/ / flatMap () sample
const myArray = ['One word'.'Two words'.'Three words']
// Delimit the strings in the array with Spaces
const myFlatWordArray = myArray.flatMap((str) = > str.split(' '))
console.log(myFlatWordArray)
// Output:
// [ 'One', 'word', 'Two', 'words', 'Three', 'words' ]
Copy the code
Object. FromEntries () method
When you need to convert objects into arrays, you can use the Entries () method, but there was no way to combine arrays of objects into single objects until ES2019. ES2019 provides the fromEntries() method. What this method does is very simple. It accepts an iteration of key-value pairs, such as arrays or maps. It then converts it to an object.
// Convert an array to an object:
const myArray = [
['name'.'Joe'],
['age'.33],
['favoriteLanguage'.'JavaScript']]const myObj = Object.fromEntries(myArray)
console.log(myObj)
// Output:
/ / {
// name: 'Joe',
// age: 33,
// favoriteLanguage: 'JavaScript'
// }
// Convert Map to object:
const myMap = new Map([['name'.'Spike'],
['species'.'dog'],
['age'.3]])const myObj = Object.fromEntries(myMap)
console.log(myObj)
// Output:
/ / {
// name: 'Spike',
// species: 'dog',
// age: 3
// }
Copy the code
The catch argument becomes optional
Previously, when you used try… To catch, you must pass the exception as an argument to the catch, even if you don’t use it. ES2019 makes this parameter optional. If you don’t want to use exceptions, you can use catch blocks with no arguments.
// Before ES2019:
try {
// Do something.
} catch (e) {
// the exception parameter e is not used
// However, this parameter cannot be omitted
}
// ES2019:
try {
// Do something.
} catch {
// Do not use the exception parameter, can be omitted
}
Copy the code
summary
These five features are the ones I find useful. In addition to these five features, the ES2019 standard adds other features or improvements that are not listed in this article but are available in the official documentation if you are interested.