Home >Web Front-end >JS Tutorial >Some super useful features in JavaScript over the past five years!
Technology is always evolving, and JavaScript has undergone a lot of changes since its inception in 1995. It has added many new features since then. This article discusses some of the super useful (but probably lesser-known) features that have been added to JavaScript in the last 5 years! But it doesn't cover all features.
The two string methods fill the string into Quick and easy method for other strings. As the name suggests, String.padStart()
adds a new string to the beginning of the given string, and String.padEnd()
appends a string to the beginning of the given string. end.
Note: These methods do not change the original string.
Let's look at an example:
Code example:
//最初的字符串 let originalString = 'Script'; //对原始的字符串添加字符串 let paddedString = originalString.padStart(10, 'Java'); console.log(paddedString); // 输出 --> // 'JavaScript'
If "we want the new string length" shorter than "the length of the original string to be added". What happens?
In this case, we add
to the string that will be added to the beginning of the original string
The excess part will be truncated.
Example:
let originalString = 'Script'; let paddedString = originalString.padStart(7, 'Java'); console.log(paddedString); // 输出 --> // 'JScript' // 把将要添加到原始字符串开头的字符串从“Java”截断为“J”
If we want the length of the new string to be longer than ' the length of the original string the string to be added "What should I do if 长?
This may cause the results not to meet our expectations! It will
repeate
the string that will be added to the beginning of the original string until it equals our desired length of the new string
Code example:
let originalString = 'Script'; let paddedString = originalString.padStart( 15, 'Java'); console.log(paddedString); // 输出 --> // 'JavaJavaJScript'What if the "string to be added to the beginning of the original string" parameter is not provided?
It will add spacesin front of the
of the
original string until the string length equals our desired new string length
Code example:
let originalString = 'Script'; let paddedString = originalString.padStart(15); console.log(paddedString); // 输出 --> // " Script"Finally, what if the "new string length we want" parameter is not provided?
It will return acopy
of the original string intact:
Code example:
let originalString = 'Script'; let paddedString = originalString.padStart('Java'); console.log(paddedString); // 输出 --> // 'Script'
String.padStart() but appends the string to the end of the given string.
Code example:
let originalString = 'Web'; let paddedString = originalString.padEnd(6, 'Dev'); console.log(paddedString); // 输出 --> // 'WebDevThe same rules apply for parameter usage:
String.replace() before, it accepts a pattern parameter and a replacement parameter, and replaces the first occurrence of the matching pattern in the string. The pattern parameter can be a
string or a
RegEx.
String.replaceAll() is more powerful, as the name suggests, it allows us to replace all occurrences of the specified pattern with the replacement string, not just the first occurrence.
Code examples:
// 使用示例 String.replace() const aString = 'My name is z. z is my name.'; const replaceString = aString.replace('z', 'zayyo'); console.log(replaceString); // 输出 --> // "My name is zayyo. z is my name." // 仅仅吧第一个“z”被替换为“zayyo” // 使用示例 String.replaceAll() with regex const regex = /z/ig; const anotherString = 'My name is z. z is my name.'; const replaceAllString = anotherString.replaceAll(regex, 'zayyo'); console.log(replaceAllString); // 输出 --> // ""My name is zayyo. zayyo is my name."." // 把所有的z都替换成zayyo了
此对象方法接收一个对象并返回一个新的二维数组,每个嵌套数组都包含原始对象的键和值作为元素。
代码示例:
const fruitObject = { 'banana': 'yellow', 'strawberry': 'red', 'tangerine': 'orange' }; const fruitArray = Object.entries(fruitObject); console.log(fruitArray); // 输出 --> // [["banana", "yellow"], ["strawberry", "red"], ["tangerine", "orange"]]
在转换我们的数据时,这是一种超级好用的方法。下面这个示例是访问对象中的特定键值对的用法:
代码示例:
const fruitObject = { 'banana': 'yellow', 'strawberry': 'red', 'tangerine': 'orange' }; const firstFruit = Object.entries(fruitObject)[0]; console.log(firstFruit); // 输出 --> // ['banana', 'yellow']
在JavaScript 中的很多东西都是对象的形式保存的。因此,我们还可以将数组和字符串作为参数传入给Object.entries()
它们会强制把数组和字符串转换为对象。
代码示例:
const string = 'Hello' const stringAsArgument = Object.entries(string); console.log(stringAsArgument); // 输出 --> // [["0", "H"], ["1", "e"], ["2", "l"], ["3", "l"], ["4", "o"]]
字符串中的每个字符都被插入到一个单独的数组中,并将其索引设置为数组的第一个元素。当您将数组作为参数传递时,也会发生一样的操作:
const array = [1,2,3] const formattedArray = Object.entries(array);console.log(formattedArray);// 输出 --> // [["0", 1], ["1", 2], ["2", 3]]复制代码
注意: 对于这两种情况,第一个元素(索引)都是一个字符串。
Object.keys
方法接受一个对象作为参数,并且返回一个以对象的键作为元素的数组。
代码示例:
const programmingLangs = { 'JavaScript': 'Brendan Eich', 'C': 'Dennis Ritchie', 'Python': 'Guido van Rossum' }; const langs = Object.keys(programmingLangs); console.log(langs); // 输出 --> // ["JavaScript", "C", "Python"]
如果我们尝试传递一个字符串作为参数呢?会是什么结果呢?
代码示例:
const string = 'Hallo'; const stringArray = Object.keys(string); console.log(stringArray); // 输出 --> // ["0", "1", "2", "3", "4"]
在这种情况下,字符串也会被强制转换为一个对象。每个字母代表值,它的索引代表键,所以我们返回的数组,就变成了包含字符串中每个字母的索引。
Object.values()
方法的功能和我们刚刚学习的方法类似,但它不是返回数组中的对象键,而是返回数组中的对象值。
代码示例:
const programmingLangs = { 'JavaScript': 'Brendan Eich', 'C': 'Dennis Ritchie', 'Python': 'Guido van Rossum' }; const creators = Object.values(programmingLangs); console.log(creators); // 输出 --> // ["Brendan Eich", "Dennis Ritchie", "Guido van Rossum"]
Object.entries()
和我们在之前学习Object.keys()
一样,我们也可以传入其他数据类型,例如字符串。
代码示例:
const string = 'Bonjour' const stringArray = Object.values(string); console.log(stringArray) // 输出 --> // ["B", "o", "n", "j", "o", "u", "r"]
Object.fromEntries()
与Object.entries()
相反。它接受一个可迭代对象作为参数,例如数组或映射,并返回一个对象。让我们来看看:
代码示例:
const arrayTranslations = [ ['french', 'bonjour'], ['spanish', 'buenos dias'], ['czech', 'dobry den'] ]; const objectTranslations = Object.fromEntries(arrayTranslations); console.log(objectTranslations); // 输出 --> /*Object { french: "bonjour", spanish: "buenos dias", czech: "dobry den" }*/
因此,我们的可迭代对象(在示例中的嵌套数组)被迭代,并且每个子数组都转换为一个对象,其中索引 0 处的元素作为键,索引 1 处的元素作为值。
因为内容太多后续会继续补全,也欢迎大家在评论区补充..
更多编程相关知识,请访问:编程教学!!
The above is the detailed content of Some super useful features in JavaScript over the past five years!. For more information, please follow other related articles on the PHP Chinese website!