您可能从未使用过的鲜为人知的 Javascript 功能

您可能从未使用过的鲜为人知的 javascript 功能

阅读原始网址 https://devaradise.com/lesser-known-javascript-features 中的帖子以获得更好的导航

javascript 是现代 web 开发的基石,为动态网站和应用程序提供动力。虽然许多开发人员熟悉 javascript 的基本且广泛使用的功能,但许多隐藏功能常常被忽视。这些鲜为人知的功能可以让你的代码更加简洁、可读、强大。

在本文中,我们将探索一些隐藏的 javascript 功能。从空合并运算符到 map 和 set 对象,每个功能都包含实际示例和最佳实践。利用这些功能可以帮助您编写更清晰、更高效的代码并轻松解决复杂的问题。

无论您是经验丰富的开发人员还是初学者,本文都将向您介绍未充分利用的 javascript 功能。最后,您将掌握新技术来提高您的 javascript 编码技能。

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

关于 javascript 的其他帖子

javascript 数组/对象解构解释 + 示例在 javascript 中克隆嵌套对象/数组(深度克隆)的正确方法

鲜为人知的 javascript 功能

1. 空值合并运算符

空合并运算符 (??) 用于在变量为 null 或未定义时提供默认值。

代码示例:

let foo = null;let bar = foo ?? 'default value';console.log(bar); // output: 'default value'

使用空值合并运算符来处理可能出现 null 或未定义值的情况,确保您的代码使用默认值顺利运行。

2. 可选链接

可选的链接运算符 (?.) 允许安全访问深层嵌套的对象属性,避免属性不存在时出现运行时错误。

代码示例:

const user = {    profile: {        name: 'alice'    }};const userprofilename = user.profile?.name;console.log(userprofilename); // output: 'alice'const useraccountname = user.account?.name;console.log(useraccountname); // output: undefined

使用可选链来避免访问可能为空或未定义对象的属性时出现错误,使您的代码更加健壮。

3. 数字分隔符

数字分隔符 (_) 通过视觉上分隔数字,使大数字更易于阅读。

代码示例:

const largenumber = 1_000_000;console.log(largenumber); // output: 1000000

使用数字分隔符可以提高代码中大数字的可读性,特别是对于财务计算或大型数据集。

4. promise.allsettled

promise.allsettled 等待所有承诺解决(履行或拒绝)并返回描述结果的对象数组。

代码示例:

const promises = [promise.resolve('success'), promise.reject('error'), promise.resolve('another success')];promise.allsettled(promises).then((results) => {    results.foreach((result) => console.log(result));});// output:// { status: 'fulfilled', value: 'success' }// { status: 'rejected', reason: 'error' }// { status: 'fulfilled', value: 'another success' }

当您需要处理多个 promise 并希望确保所有结果都得到处理时,无论单个 promise 结果如何,请使用 promise.allsettled。

5. 私有类字段

私有类字段是只能在声明的类中访问和修改的属性。

代码示例:

class myclass {    #privatefield = 42;    getprivatefield() {        return this.#privatefield;    }}const instance = new myclass();console.log(instance.getprivatefield()); // output: 42console.log(instance.#privatefield); // uncaught private name #privatefield is not defined.

使用私有类字段将数据封装在类内,确保敏感数据不会在类外暴露或修改。

6. 逻辑赋值运算符

逻辑赋值运算符(&&=、||=、??=)将逻辑运算符与赋值相结合,提供了一种根据条件更新变量的简洁方法。

代码示例:

let a = true;let b = false;a &&= 'assigned if true';b ||= 'assigned if false';console.log(a); // output: 'assigned if true'console.log(b); // output: 'assigned if false'

使用逻辑赋值运算符来简化条件赋值,使您的代码更具可读性和简洁性。

7. 循环和块语句的标签

标签是后跟冒号的标识符,用于标记循环或块以供在 break 或 continue 语句中引用。

代码示例:

outerloop: for (let i = 0; i < 3; i++) {    console.log(`outer loop iteration ${i}`);    for (let j = 0; j < 3; j++) {        if (j === 1) {            break outerloop; // break out of the outer loop        }        console.log(`  inner loop iteration ${j}`);    }}// output:// outer loop iteration 0//   inner loop iteration 0
labelblock: {    console.log('this will be printed');    if (true) {        break labelblock; // exit the block    }    console.log('this will not be printed');}// output:// this will be printed

使用标签来控制复杂的循环行为,可以更轻松地管理嵌套循环并提高代码清晰度。

8. 标记模板文字

标记模板文字允许您使用函数解析模板文字,从而实现字符串文字的自定义处理。

代码示例1:

function logwithtimestamp(strings, ...values) {    const timestamp = new date().toisostring();    return (        `[${timestamp}] ` +        strings.reduce((result, str, i) => {            return result + str + (values[i] || '');        })    );}const user = 'johndoe';const action = 'logged in';console.log(logwithtimestamp`user ${user} has ${action}.`);// outputs: [2024-07-10t12:34:56.789z] user johndoe has logged in.

代码示例2:

function validate(strings, ...values) {    values.foreach((value, index) => {        if (typeof value !== 'string') {            throw new error(`invalid input at position ${index + 1}: expected a string`);        }    });    return strings.reduce((result, str, i) => {        return result + str + (values[i] || '');    });}try {    const validstring = validate`name: ${'alice'}, age: ${25}`;    console.log(validstring); // this will throw an error} catch (error) {    console.error(error.message); // outputs: invalid input at position 2: expected a string}

使用标记模板文字进行高级字符串处理,例如创建安全的 html 模板或本地化字符串。

9. 用于快速数学的按位运算符

javascript 中的位运算符对数字的二进制表示形式执行运算。它们通常用于低级编程任务,但它们也可以方便地进行快速数学运算。

按位运算符列表

&(和)| (或)^(异或)〜(不是)<> (右移)>>> (无符号右移)

代码示例1:

您可以使用 and 运算符来检查数字是偶数还是奇数。

const iseven = (num) => (num & 1) === 0;const isodd = (num) => (num & 1) === 1;console.log(iseven(4)); // outputs: trueconsole.log(isodd(5)); // outputs: true

代码示例2:

可以使用左移(<>)运算符分别乘以2的幂和除以2的幂。

const multiplybytwo = (num) => num < num >> 1;console.log(multiplybytwo(5)); // outputs: 10console.log(dividebytwo(10)); // outputs: 5

代码示例3:

您可以使用 and 运算符检查数字是否为 2 的幂。

const ispoweroftwo = (num) => num > 0 && (num & (num - 1)) === 0;console.log(ispoweroftwo(16)); // outputs: trueconsole.log(ispoweroftwo(18)); // outputs: false

将按位运算符用于需要低级二进制操作的性能关键型应用程序,或进行快速数学运算。

10. 财产检查操作员

in 运算符检查对象中是否存在属性。

极简智能王 极简智能王

极简智能- 智能聊天AI绘画,还可以创作、编写、翻译、写代码等多种功能,满足用户生活和工作的多方面需求

极简智能王 33 查看详情 极简智能王

代码示例:

const obj = { name: 'alice', age: 25 };console.log('name' in obj); // output: trueconsole.log('height' in obj); // output: false

使用 in 运算符来验证对象中属性是否存在,确保您的代码能够优雅地处理缺少属性的对象。

11. 调试器语句

调试器语句调用任何可用的调试功能,例如在代码中设置断点。

代码示例:

function checkvalue(value) {    debugger; // execution will pause here if a debugger is available    return value > 10;}checkvalue(15);

在开发过程中使用调试器语句来暂停执行并检查代码行为,帮助您更有效地识别和修复错误。

12. 链式赋值

链式赋值允许您在单个语句中将单个值分配给多个变量。

代码示例:

let a, b, c;a = b = c = 10;console.log(a, b, c); // output: 10 10 10

使用链式赋值来初始化具有相同值的多个变量,减少代码冗余。

13. 动态函数名称

动态函数名称允许您使用在运行时计算的名称来定义函数。

代码示例:

const funcname = 'dynamicfunction';const obj = {    [funcname]() {        return 'this is a dynamic function';    }};console.log(obj.dynamicfunction()); // output: 'this is a dynamic function'

使用动态函数名称,根据运行时数据创建名称的函数,增强代码灵活性和可重用性。

14. 获取函数参数

arguments 对象是一个类似数组的对象,其中包含传递给函数的参数。

代码示例:

function sum() {    let total = 0;    for (let i = 0; i < arguments.length; i++) {        total += arguments[i];    }    return total;}console.log(sum(1, 2, 3)); // outputs: 6

使用参数对象来访问传递给函数的所有参数,这对于具有可变长度参数的函数很有用。

15. 一元+运算符

一元运算符 (+) 将其操作数转换为数字。

代码示例:

console.log(+'abc'); // outputs: nanconsole.log(+'123'); // outputs: 123console.log(+'45.67'); // outputs: 45.67 (converted to a number)console.log(+true); // outputs: 1console.log(+false); // outputs: 0console.log(+null); // outputs: 0console.log(+undefined); // outputs: nan

使用一元运算符进行快速类型转换,尤其是在处理用户输入或来自外部源的数据时。

16. 求幂 ** 运算符

求幂运算符 (**) 对其操作数执行求幂(幂)操作。

代码示例:

const base = 2;const exponent = 3;const result = base ** exponent;console.log(result); // output: 8

使用幂运算符进行涉及幂的简洁易读的数学表达式,例如在科学或金融计算中。

17. 函数属性

javascript 中的函数是对象并且可以具有属性。

代码示例1:

function myfunction() {}myfunction.description = 'this is a function with a property';console.log(myfunction.description); // output: 'this is a function with a property'

代码示例2:

function trackcount() {    if (!trackcount.count) {        trackcount.count = 0;    }    trackcount.count++;    console.log(`function called ${trackcount.count} times.`);}trackcount(); // outputs: function called 1 times.trackcount(); // outputs: function called 2 times.trackcount(); // outputs: function called 3 times.

使用函数属性来存储与函数相关的元数据或配置,增强代码的灵活性和组织性。

18. 对象获取器和设置器

getter 和 setter 是获取或设置对象属性值的方法。

代码示例:

const obj = {    firstname: 'john',    lastname: 'doe',    _age: 0, // conventionally use an underscore for the backing property    get fullname() {        return `${this.firstname} ${this.lastname}`;    },    set age(newage) {        if (newage >= 0 && newage <= 120) {            this._age = newage;        } else {            console.log('invalid age assignment');        }    },    get age() {        return this._age;    }};console.log(obj.fullname); // outputs: 'john doe'obj.age = 30; // setting the age using the setterconsole.log(obj.age); // outputs: 30obj.age = 150; // attempting to set an invalid age// outputs: 'invalid age assignment'console.log(obj.age); // still outputs: 30 (previous valid value remains)

使用 getter 和 setter 来封装对象的内部状态,提供一种受控的方式来访问和修改属性。

19.!!棒棒操作员

那个!! (双重否定)运算符将值转换为其布尔值。

代码示例:

const value = 'abc';const value1 = 42;const value2 = '';const value3 = null;const value4 = undefined;const value5 = 0;console.log(!!value); // outputs: true (truthy value)console.log(!!value1); // outputs: true (truthy value)console.log(!!value2); // outputs: false (falsy value)console.log(!!value3); // outputs: false (falsy value)console.log(!!value4); // outputs: false (falsy value)console.log(!!value5); // outputs: false (falsy value)

使用!!运算符可快速将值转换为布尔值,在条件表达式中很有用。

20.映射和设置对象

map 和 set 是具有独特功能的集合。 map 保存键值对,set 保存唯一值。

代码示例1:

// creating a mapconst mymap = new map();// setting key-value pairsmymap.set('key1', 'value1');mymap.set(1, 'value2');mymap.set({}, 'value3');// getting values from a mapconsole.log(mymap.get('key1')); // outputs: 'value1'console.log(mymap.get(1)); // outputs: 'value2'console.log(mymap.get({})); // outputs: undefined (different object reference)

代码示例2:

// Creating a Setconst mySet = new Set();// Adding values to a SetmySet.add('apple');mySet.add('banana');mySet.add('apple'); // Duplicate value, ignored in a Set// Checking size and valuesconsole.log(mySet.size); // Outputs: 2 (only unique values)console.log(mySet.has('banana')); // Outputs: true// Iterating over a SetmySet.forEach((value) => {    console.log(value);});// Outputs:// 'apple'// 'banana'

使用map来集合任意数据类型作为键的键值对集合,使用set来集合唯一值,提供高效的数据管理方式。

结论

通过利用这些鲜为人知的 javascript 功能,您可以编写更高效、可读且健壮的代码。开始将这些技术集成到您的项目中,将您的 javascript 技能提升到一个新的水平。

我们希望本指南为您提供有价值的见解和实际示例,以帮助您利用这些隐藏的 javascript 功能。不要犹豫,尝试一下它们,看看它们如何适合您的编码实践。

如果您觉得这篇文章有帮助,请与您的开发人员和朋友分享。我很想听听您对这些功能的想法和体验,所以请随时在下面发表评论。

谢谢。快乐编码!

以上就是您可能从未使用过的鲜为人知的 Javascript 功能的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 08:10:19
下一篇 2025年11月8日 08:14:40

相关推荐

  • 如何直接访问 Sass 地图变量的值?

    直接访问 sass 地图变量的值 在 sass 中,我们可以使用地图变量来存储一组键值对。而有时候,我们可能需要直接访问其中的某个值。 可以通过 map-get 函数直接从地图中获取特定的值。语法如下: map-get($map, $key) 其中: $map 是我们要获取值的 sass 地图变量。…

    2025年12月24日
    000
  • 点击按钮后为什么它还保持着 :focus 样式?

    为什么按钮点击后保持 :focus 样式? 在您的案例中,按钮点击后仍然保持 :focus 样式,这是由于按钮处于 focus 状态所致。当元素处于 focus 状态时,表示该元素可以与键盘交互,此时会触发某些视觉效果,如边框变色或带有光标。 对于按钮而言,focus 状态的作用包括: 使用空格键触…

    2025年12月24日
    300
  • 我如何编写 CSS 选择器

    CSS 方法有很多,但我都讨厌它们。有些多(顺风等),有些少(BEM、OOCSS 等)。但归根结底,它们都有缺陷。 当然,人们使用这些方法有充分的理由,并且解决的许多问题我也遇到过。因此,在这篇文章中,我想写下我自己的关于如何保持 CSS 井井有条的指南。 这并不是一个任何人都可以开始使用的完整描述…

    2025年12月24日
    000
  • 不惜一切代价避免的前端开发错误

    简介 前端开发对于创建引人入胜且用户友好的网站至关重要。然而,在这方面犯错误可能会导致用户体验不佳、性能下降,甚至出现安全漏洞。为了确保您的网站是一流的,必须认识并避免常见的前端开发错误。 常见的前端开发错误 缺乏计划 跳过线框 跳过线框图过程是一种常见的疏忽。线框图有助于在任何实际开发开始之前可视…

    2025年12月24日
    000
  • ro CSS 技巧会让你大吃一惊

    css(层叠样式表)是网页设计中最流行的技术之一,允许开发人员创建视觉和响应式设计。作为一名 web 开发人员,掌握 css 对于将您的设计愿景变为现实并确保在所有设备上提供良好的用户体验至关重要。以下是一些你可能不知道的 css 技巧: 1.新形态: neumorphsime,即软ui设计,是拟物…

    2025年12月24日
    000
  • html5怎么删除缓存_html5用JS清除localStorage/sessionStorage或清浏览器缓存【清除】

    清除HTML5网页缓存需分五步:一、用localStorage.clear()清本地存储;二、用sessionStorage.clear()清会话存储;三、用location.reload(true)强制刷新;四、在head中添加三行meta禁用页面缓存;五、手动清除浏览器HTTP缓存。 如果您在使…

    2025年12月23日
    000
  • html5怎么写样式_html5用style内嵌或外部css文件写元素样式【写法】

    HTML5样式设置有三种方式:一、内联style属性,仅作用于当前元素;二、标签内嵌CSS,作用于整个文档;三、引入外部CSS文件,实现结构与样式分离;优先级为内联>内嵌/外部,后加载覆盖先加载。 如果您希望为HTML5文档中的元素设置样式,可以通过内嵌style属性或引入外部CSS文件来实现…

    2025年12月23日
    000
  • HTML如何获取URL参数_GET请求处理技术【指南】

    应使用URLSearchParams接口解析查询参数,它兼容现代浏览器且语法简洁;若需兼容老旧浏览器,则可手动分割字符串并解码;推荐封装为parseUrlParams()函数,并注意对键值进行decodeURIComponent解码及HTML转义以防XSS。 如果您需要在HTML页面中提取当前URL…

    2025年12月23日
    000
  • vscode设置html5环境_插件配置与代码片段设置【教程】

    若VS Code中HTML文件缺乏语法高亮、智能补全及HTML5结构快速生成,需安装Auto Close Tag、Auto Rename Tag、CSS class IntelliSense和HTML Boilerplate插件,启用Emmet并配置html关联与格式化设置。 如果您在 Visual…

    2025年12月23日
    000
  • HTML如何重置表单数据_JavaScript清空操作指南【教程】

    可通过五种JavaScript方法清空HTML表单:一、调用form.reset()恢复默认值;二、遍历控件手动设空或重置状态;三、重置innerHTML但需重新绑定事件;四、操作FormData对象删除键值;五、单独清空指定字段。 如果您在网页中使用了HTML表单,但需要将所有输入字段恢复为初始状…

    2025年12月23日
    000
  • html5清除缓存方法_本地存储与缓存清理技巧【教程】

    HTML5应用异常多因缓存或本地存储残留旧数据,需分别清除浏览器常规缓存与Cookie、localStorage/sessionStorage、IndexedDB、Service Worker缓存,开发时可禁用缓存调试。 如果您在使用HTML5应用时遇到页面内容未更新、数据错乱或加载异常等问题,很可…

    2025年12月23日
    000
  • html如何存储_使用Web Storage等存储HTML页面数据【数据】

    可在浏览器中用Web Storage API持久化保存HTML数据:一、localStorage永久存键值对;二、sessionStorage暂存标签页级数据;三、存取HTML字符串片段;四、IndexedDB存复杂结构化数据;五、结合data-*属性批量序列化表单。 如果需要在浏览器中持久化保存H…

    2025年12月23日
    000
  • HTML如何向页面传参_URL参数传递技术解析【技巧】

    URL参数传递有五种方法:一、JavaScript解析URLSearchParams;二、手动拼接编码后的URL跳转;三、表单GET提交自动组装参数;四、锚点hash模拟传参;五、服务端预注入参数到HTML。 如果您需要在HTML页面之间传递数据,URL参数是一种轻量且广泛支持的方式。以下是实现UR…

    2025年12月23日
    000
  • html5如何合并表单_html5表单合并实现步骤【表单处理】

    HTML5表单合并可通过四种方式实现:一、用form属性关联独立控件;二、用JavaScript收集多表单数据统一提交;三、嵌套fieldset语义化合并;四、用FormData接口动态追加字段。 如果您需要将多个HTML5表单整合为一个统一提交入口,或在单页应用中动态聚合分散的表单数据,则需通过结…

    2025年12月23日
    000
  • HTML如何实现记忆功能_本地存储应用方案【技巧】

    网页记忆功能可通过五种本地存储机制实现:一、localStorage持久化键值对;二、sessionStorage限于当前会话;三、JSON序列化存取复杂数据;四、cookies支持跨页面与服务端共享;五、IndexedDB处理大规模结构化数据。 如果您希望网页在用户关闭后仍能保留之前输入的数据或设…

    2025年12月23日
    000
  • HTML如何定义数据属性_自定义属性使用教程【技巧】

    可使用data属性存储页面行为相关元数据。需以data-开头、全小写命名,通过dataset API(驼峰式)或getAttribute/setAttribute(连字符式)读写,并支持CSS属性选择器匹配。 如果您希望在HTML元素中存储与页面行为相关的额外信息,而又不希望这些信息影响样式或布局,…

    2025年12月23日
    000
  • HTML如何获取URL参数_GET请求数据处理方法【解析】

    推荐使用URLSearchParams接口解析URL查询参数,它兼容主流浏览器、语法简洁且支持增删改查;旧版浏览器可手动解析location.search字符串;还可封装函数支持默认值与类型转换,或通过URL构造器解析任意URL。 如果您在HTML页面中需要读取当前URL中的查询参数(即类似?nam…

    好文分享 2025年12月23日
    000
  • HTML如何获取输入框数值_JavaScript取值方法【教程】

    获取用户输入数值需按场景选择方法:一、getElementById+value;二、querySelector+value;三、form.elements+name/index;四、监听input事件实时获取;五、FormData批量提取。 如果您在网页中使用HTML创建了输入框,并希望借助Java…

    2025年12月23日
    000
  • 如何解释html5_HTML5技术解释与核心概念入门指南【教程】

    HTML5是HTML第五版,整合语义化标签、原生音视频、Canvas绘图及localStorage/sessionStorage存储。1、语义标签如提升结构与可访问性;2、支持免插件多媒体,含;3、配合JS实现2D绘图;4、localStorage持久存储,sessionStorage限会话期。 一…

    2025年12月23日
    000
  • JavaScript中Data属性的获取与元素选择教程

    本文详细介绍了如何在javascript中有效地获取html元素的自定义`data-*`属性值,以及如何利用css属性选择器来定位和操作不依赖`id`或`class`的html元素。通过`htmlelement.dataset` api和`document.queryselector`/`query…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信