您可能从未使用过的鲜为人知的 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)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
汽车救援APP的实用功能及智能化优势
上一篇 2025年11月8日 08:10:38
找不到msvcp100.dll怎么办?msvcp100.dll文件丢失修复方法
下一篇 2025年11月8日 08:10:48

相关推荐

  • Golang JSON序列化:控制敏感字段暴露的最佳实践

    本教程探讨golang中如何高效控制结构体字段在json序列化时的可见性。当需要将包含敏感信息的结构体数组转换为json响应时,通过利用`encoding/json`包提供的结构体标签,特别是`json:”-“`,可以轻松实现对特定字段的忽略,从而避免敏感数据泄露,确保api…

    2026年5月10日
    000
  • 如何在HTML中插入表单元素_HTML表单控件与输入类型使用指南

    HTML表单通过标签构建,包含action和method属性定义数据提交目标与方式,常用input类型如text、password、email等适配不同输入需求,配合label、required、placeholder提升可用性,结合textarea、select、button等控件实现完整交互,是…

    2026年5月10日
    100
  • 怎么在手机上把XML文件转换为PDF?

    不可能直接在手机上用单一应用完成 XML 到 PDF 的转换。需要使用云端服务,通过两步走的方式实现:1. 在云端转换 XML 为 PDF,2. 在手机端访问或下载转换后的 PDF 文件。 怎么在手机上把XML文件转换为PDF? 这问题问得好,比直接问“怎么转换”有深度多了!因为它触及了移动端环境的…

    2026年5月10日
    000
  • 深入理解 Laravel Session::put:避免常见陷阱与实现表单限流

    本文旨在深入探讨 laravel 框架中 `session::put` 方法的正确用法及其常见误区。针对用户在实现表单提交限流时遇到的问题,详细阐述了 `session::put` 必须提供键值对的原理,并提供了如何在控制器中利用会话机制有效防止重复提交的实战代码示例。通过本文,读者将掌握 lara…

    2026年5月10日
    000
  • jQuery对象类型判断机制详解:toType函数如何精准识别对象类型?

    深入解析jquery对象类型判断机制:totype函数详解 本文将深入剖析jQuery中用于精准识别对象类型的toType函数,并详细解释其核心代码片段。该函数旨在判断传入对象的类型并返回其类型字符串。 核心代码如下: var class2type = {};var toString = class…

    2026年5月10日
    000
  • JavaScript中为动态列表元素创建唯一悬停描述的教程

    本教程旨在解决如何为动态生成的列表或数组元素分配唯一悬停描述(tooltip)的问题。文章将深入探讨使用javascript对象和map数据结构来高效地管理名称与描述的映射关系,并提供具体的代码示例,以实现每个列表项在鼠标悬停时显示不同的自定义信息,同时兼顾性能与数据顺序的需求。 在网页开发中,我们…

    2026年5月10日
    000
  • PHP中通过键名高效关联与输出多维数组数据

    本教程旨在解决php开发中常见的数据关联与输出问题,特别是当需要将不同数组中通过共同键名关联的数据进行整合展示时。文章将详细阐述如何利用foreach循环的键值对特性,结合array_key_exists函数,实现从多个数组中提取并组合相关信息,从而避免不必要的嵌套循环,提升代码的清晰度和执行效率。…

    2026年5月10日
    000
  • python中怎么删除字典中的键值对_Python删除字典元素的方法

    删除字典键值对有四种方法:del语句删除指定键,pop()删除键并返回值,popitem()随机删除键值对,clear()清空字典。 在 Python 中,删除字典中的键值对主要有几种方式:使用 del 语句直接删除指定键,利用 pop() 方法删除指定键并获取其对应的值,或者通过 popitem(…

    2026年5月10日
    000
  • 怎样用Golang实现一个简单的键值存储 基于文件持久化方案

    怎样用Golang实现一个简单的键值存储 基于文件持久化方案怎样用Golang实现一个简单的键值存储 基于文件持久化方案怎样用Golang实现一个简单的键值存储 基于文件持久化方案怎样用Golang实现一个简单的键值存储 基于文件持久化方案

    要实现一个简单的键值存储系统,需结合golang与文件持久化方案。1. 使用map[string]string作为内存数据结构,选择json或gob进行序列化;2. 围绕map实现crud操作,写入后立即或定时刷新到磁盘,并在启动时加载数据;3. 文件策略可选每次写入刷盘、定时异步刷盘或日志记录变更…

    2026年5月10日 用户投稿
    000
  • js怎么处理AJAX请求的响应

    在 javascript 中处理 ajax 请求的响应可以通过以下步骤实现:1) 使用 fetch api 发送请求并接收响应;2) 检查响应状态并解析 json 数据;3) 处理数据并更新界面;4) 使用 catch 捕获并处理错误。这不仅涉及技术细节,还需要考虑用户体验和性能优化,例如错误处理、…

    2026年5月10日
    000
  • C++ 数据结构指南:理清复杂数据组织之道

    答案: c++++ 数据结构是组织和管理数据的构建块,优化检索和处理。常见结构:数组:有序集合,通过索引访问向量:动态数组,快速插入和删除链表:灵活插入和删除堆栈:lifo 原则队列:fifo 原则树:分层结构哈希表:快速键值查找应用: 数据存储、算法设计、图形处理、人工智能等。实战案例: 使用学生…

    2026年5月10日
    000
  • php实现哪些功能

    PHP是一种通用脚本语言,可用来实现广泛的功能,包括:动态Web开发:生成响应用户请求的动态 веб页面。内容管理系统(CMS):构建允许用户管理网站内容的CMS。电子商务:开发具有购物车、订单处理和支付网关集成的电子商务网站。服务器端编程:编写命令行脚本和工具。文件操作:创建、读取、写入和删除文件…

    2026年5月10日
    000
  • 从LocalStorage中获取并显示特定JSON对象属性的教程

    本文详细介绍了如何从浏览器localstorage中检索存储为json字符串的复杂数据,并提取其中的特定属性值以显示在网页元素中。核心方法是使用`json.parse()`将存储的字符串转换回javascript对象,然后通过点或方括号语法访问所需属性。文章还提供了示例代码和错误处理建议,确保数据获…

    2026年5月10日
    100
  • JavaScript数据结构实现_javascript算法基础

    JavaScript中常用数据结构包括栈、链表和字典:1. 栈利用数组的push和pop实现LIFO,适用于括号匹配;2. 链表由节点组成,插入删除高效,适合频繁修改场景;3. 字典用对象实现键值对存储,常用于频率统计;4. 二分查找在有序数组中以O(log n)效率查找目标值,需数组已排序。掌握这…

    2026年5月10日
    000
  • python中del是什么意思 python中del删除对象的用法解析

    在python中,del用于删除对象的引用。1)删除变量:del x会移除变量x的引用,导致x不再存在。2)删除列表元素:del my_list[2]会删除索引为2的元素。3)删除列表切片:del my_list[1:3]会删除指定范围内的元素。4)删除字典键值对:del my_dict[&#821…

    2026年5月10日
    000
  • Laravel Session::put 正确用法详解与常见误区规避

    本文详细探讨了 laravel 中 `session::put` 方法的正确用法,特别指出在仅提供键名而未指定值时可能导致会话数据未被正确设置的问题。通过示例代码,阐述了如何为会话数据赋予明确的值,并演示了如何正确地检查和获取会话数据,以确保会话管理功能按预期工作,有效避免常见的会话操作错误。 La…

    2026年5月10日
    000
  • PHP中批量为嵌套数组元素添加公共属性的教程

    本教程将详细介绍在php中如何高效地为包含多个关联数组的集合中的每个子数组添加一个或多个新的公共键值对。我们将探讨使用循环和数组合并函数实现这一目标的方法,并提供清晰的代码示例,帮助开发者处理此类数据结构转换。 在PHP开发中,我们经常会遇到处理复杂数据结构的需求,其中一种常见场景是拥有一个由多个关…

    2026年5月10日
    000
  • 掌握Python中嵌套列表与字典的数据访问技巧

    本文详细介绍了在Python中如何高效且准确地访问复杂嵌套数据结构(特别是包含列表和字典的多层JSON数据)中的特定值。通过具体示例,文章解释了直接索引列表元素和字典键的正确方法,避免了常见的类型错误,并提供了处理多条记录和潜在数据缺失的健壮性建议,旨在帮助开发者熟练提取深层数据。 理解嵌套数据结构…

    2026年5月10日
    000
  • 如何通过URL查询参数在不同HTML页面间传递数据

    本教程详细阐述了如何在不同HTML页面之间传递数据,特别聚焦于使用URL查询参数的方法。我们将通过一个点餐系统示例,演示如何从一个菜单页面获取商品名称和价格,并通过点击按钮将其安全地传递到支付页面,并在支付页面自动填充相应的表单输入框。文章涵盖了数据编码、URL构建以及在目标页面解析和使用这些数据,…

    2026年5月10日
    100
  • 如何在Python中创建XML文档?

    使用xml.etree.ElementTree创建XML的核心步骤包括:导入模块、创建根元素、添加子元素与属性、设置文本内容、生成ElementTree对象并写入文件;注意事项有:使用ET.indent()提升可读性、指定encoding=&quot;utf-8&quot;和xml_…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信