过去五年里,JavaScript中的一些超级有用的特性!

技术总是在不断发展,javascript 自 1995 年提出诞生以来发生了很多的变化,从那时起到现在它添加了许多新功能。本文讨论了过去 5 年添加到 javascript 中的一些超级有用(但可能不太为人所知)的特性!但是它并不能的囊括所有的特性。

过去五年里,JavaScript中的一些超级有用的特性!

String.padStart() 和 String.padEnd()

这两个字符串方法是将字符串填充到其他字符串的快速简便的方法。顾名思义,String.padStart()将一个新字符串添加到给定字符串的开头,并将String.padEnd()一个字符串附加到给定字符串的末尾。

注意:这些方法不会改变原始字符串。

String.padStart(desiredStringLength, stringToAdd)

desiredStringLength:你希望新字符串长度为数字的长度。【推荐学习:javascript视频教程】stringToAdd:这是要添加到原始字符串开头的字符串。

让我们看一个例子:

立即学习“Java免费学习笔记(深入)”;

代码示例:

//最初的字符串let originalString = 'Script';//对原始的字符串添加字符串let paddedString = originalString.padStart(10, 'Java');console.log(paddedString);// 输出 -->// 'JavaScript'

登录后复制

如果“我们希望的新字符串长度”“原始字符串的长度+要添加的字符串” 。会发生什么情况呢?

在这种情况下,我们把将要添加到原始字符串开头的字符串多余的部分会被截掉。

例子:

let originalString = 'Script';let paddedString = originalString.padStart(7, 'Java');console.log(paddedString);// 输出 -->// 'JScript'// 把将要添加到原始字符串开头的字符串从“Java”截断为“J”

登录后复制

如果我们希望的新字符串长度“原始字符串的长度+要添加的字符串”怎么办?

这可能会导致结果不符合我们的预期!它会把将要添加到原始字符串开头的字符串进行重复,直到它等于 我们希望的新字符串长度

代码示例:

let originalString = 'Script';let paddedString = originalString.padStart( 15, 'Java');console.log(paddedString);// 输出 -->// 'JavaJavaJScript'

登录后复制

如果没有提供 “将要添加到原始字符串开头的字符串” 参数呢?

它会在原始字符串的前面添加空格,直到字符串长度等于 我们希望的新字符串长度

代码示例:

let originalString = 'Script';let paddedString = originalString.padStart(15);console.log(paddedString);// 输出 -->// "         Script"

登录后复制

最后,没有提供 “我们希望的新字符串长度” 参数怎么办?

它会把原始字符串的副本被原封不动地返回:

代码示例:

let originalString = 'Script';let paddedString = originalString.padStart('Java');console.log(paddedString);// 输出 --> // 'Script'

登录后复制

String.padEnd(desiredStringLength, stringToAppend)

desiredStringLength:你希望新字符串长度为数字的长度。stringToAdd:这是要添加到原始字符串开头的字符串。

此字符串方法的工作方式与 String.padStart()相同,但将字符串附加到给定字符串的末尾。

代码示例:

let originalString = 'Web';let paddedString = originalString.padEnd(6, 'Dev');console.log(paddedString);// 输出 -->// 'WebDev

登录后复制

相同的规则适用于参数使用:

desiredStringLength 附加到原始字符串末尾的 stringToAppend 将被截断。desiredStringLength > 原始字符串 + stringToAppend? 将重复追加到原始字符串末尾的 stringToAppend,直到达到 desiredStringLength。没有传递 stringToAppend 参数? 空格将附加到原始字符串,直到达到 desiredStringLength。没有传递 desiredStringLength 参数? 原始字符串的副本将原封不动地返回。

String.replaceAll(pattern,replacement)

pattern:我们将要被替换的字符串replacement:我们希望替换成的字符串

你之前可能遇到过String.replace(),它接受一个pattern参数和一个replacement参数,并且替换字符串中匹配模式的第一个匹配项。pattern 参数可以是字符串也可以是RegEx。

String.replaceAll()功能更强,顾名思义,它允许我们用替换字符串替换指定模式的所有匹配项,而不仅仅是第一个匹配项。

代码示例:

// 使用示例 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 regexconst  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了

登录后复制

Object.entries()、Object.keys()、Object.values() 和 Object.fromEntries()

上面这些方法对于转换一些数据结构很有用。。

Object.entries(originalObject)

此对象方法接收一个对象并返回一个新的二维数组,每个嵌套数组都包含原始对象的键和值作为元素。

代码示例:

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(anObject)

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(anObject)

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(anIterable)

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 处的元素作为值。

因为内容太多后续会继续补全,也欢迎大家在评论区补充..

更多编程相关知识,请访问:编程教学!!

以上就是过去五年里,JavaScript中的一些超级有用的特性!的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2696055.html

(0)
上一篇 2025年3月7日 18:29:32
下一篇 2025年3月7日 18:29:43

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 详解js在html中的加载执行顺序

    js在html中的加载执行顺序 1.加载顺序:引入标记的出现顺序, 页面上的js代码是js的一部分,所以Javascript在页面装载时执行的顺序就是其引入标记的出现顺序, 标记里面的或者通过src引入的外部JS,都是按照其语句出现的顺序执…

    编程技术 2025年4月4日
    100
  • HTML和JS实现简单的计算器

    HTML和JS实现计算器功能的也是很容易的,本文主要和大家分享HTML和JS实现简单的计算器,希望能帮助到大家。 下面是代码:    nbsp;html>无标题文档 var result=””; function jisuan(num…

    编程技术 2025年4月4日
    100
  • 实现在HTML页面加载完毕后运行js方法

    本文主要和大家分享实现在HTML页面加载完毕后运行js方法,主要以代码的方法和大家分享,希望能帮助到大家。 Js方法: window.onload=function (){ var userName=”xiaoming”; alert(us…

    编程技术 2025年4月4日
    100
  • JavaScript实现获取远程的html到当前页面中

    今天做个项目,需要在当前的html页面中引用一个远程的html页面,百度了一下,发现一个非常好用的代码,这里分享给大家,有相同需求的小伙伴可以来看看 html代码 登录后复制 立即学习“Java免费学习笔记(深入)”; javascript…

    编程技术 2025年4月4日
    200
  • JavaScript模块优化

    给大家分享一下如何才能开发出更好的javascript模块和功能,有兴趣的朋友参考学习下吧。 不少人都曾经在 npm 上发布过自己开发的 JavaScript 模块,而在使用一些模块的过程中,我经常产生“这个模块很有用,但如果能 xxx 就…

    编程技术 2025年4月4日
    100
  • 适用于JavaScript开发人员的10个必备VSCode扩展

    如今,visual studio code无疑是最流行的轻量级代码编辑器。它确实从其他代码编辑器那借鉴了很多,最主要是从sublime和atom那里。然而它的成功关键是源于能提供更好的性能和稳定的表现。 另外,它还提供了如代码智能提示等开发…

    2025年4月2日 编程技术
    200
  • 提高 JavaScript 开发效率的高级 VSCode 扩展!

    如今,visual studio code无疑是最流行的轻量级代码编辑器。vs code的强大无疑来自于它的插件市场。多亏了开源社区,vs code现在几乎对所有的编程语言、框架和开发技术都有支持。 提供这种支持的方式是多样的,主要包括了为…

    2025年4月2日 编程技术
    200
  • 如何利用Vue实现拖拽穿梭框功能?四种方式介绍

    如何实现拖拽穿梭框功能?下面本篇文章给大家介绍一下vue实现拖拽穿梭框功能四种方式,希望对大家有所帮助。 【相关推荐:vue】 一、使用原生js实现拖拽 vue Lazyload .drag { background-color: skyb…

    2025年4月1日
    100
  • 聊聊MVVM模型在Vue中怎么应用

    理解MVVM模型 我们知道每一个 Vue 应用都是从创建一个新的实例开始的,根据 Vue2 的官方文档我们可以得知 Vue 的设计是得到了 MVVM 模型 的启发,所以就有了在我们创建 Vue 实例时,文档中经常使用vm这个变量名来表示 V…

    2025年4月1日 编程技术
    200
  • 浅析Vue3动态组件怎么进行异常处理

    vue3动态组件怎么进行异常处理?下面本篇文章带大家聊聊vue3 动态组件异常处理的方法,希望对大家有所帮助! 【相关推荐:vuejs视频教程】 动态组件有两种常用场景: 一是动态路由: 立即学习“前端免费学习笔记(深入)”; // 动态路…

    2025年4月1日
    100

发表回复

登录后才能评论