百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

为什么高手写 JS 总是又快又好?这10个技巧你要知道

moboyou 2025-07-12 03:47 5 浏览

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!

JavaScript 是前端开发的重要语言,但许多开发人员可能并不熟悉它的一些强大功能。以下是 10 项有助于提高编码效率的 JavaScript 技巧。

1. 使用 flatMap 进行数组操作

flatMap() 是一个多功能方法,其结合了 map() 和 flat() 的功能,可以将数组展平一层,该方法非常适合以更简洁的语法管理嵌套数据。

同时,flatMap 可用于在映射过程中动态添加和移除项,即其允许将多个项映射到多个项而非始终保持一对一映射。从这个意义上讲,其作用类似于 filter 的反面,返回包含 1 个元素的数组来保留项,返回一个包含多个元素的数组来添加项,返回一个包含 0 个元素的数组来移除项。

console.log([1, 2, , 4, 5].flatMap((x) => [x, x * 2]));
// 输出 [1, 2, 2, 4, 4, 8, 5, 10]
console.log([1, 2, 3, 4].flatMap((x) => [, x * 2]));
// 输出 [2, 4, 6, 8]

2. 利用高级 console 方法

JavaScript 的控制台对象提供的功能远不止 console.log(),其还包含用于测量性能的 console.time 方法、用于结构化输出的 console.dir 方法以及用于堆栈跟踪的 console.trace 方法。

console.time("fetch time");
fetch("https://reqres.in/api/users").then(() => console.timeEnd("fetch time"));
// 以上代码测量时间

console.dir() 静态方法显示指定 JavaScript 对象的属性列表。在浏览器控制台中,输出以带有三角形标记的层级列表形式呈现以便查看子对象的内容。

console.dir(object);
console.dir(object, options);

而 console.trace() 静态方法将堆栈跟踪输出到控制台:

function foo() {
  function bar() {
    console.trace();
  }
  bar();
}
foo();

3. 使用 structuredClone() 进行深度克隆

JavaScript 中新增的 structuredClone() 方法提供了一种简单、高效的方法来对对象进行深度克隆,即使是复杂类型。

const original = {name: "MDN"};
original.itself = original;
// 克隆
const clone = structuredClone(original);
console.assert(clone !== original);
// 对象不一样
console.assert(clone.name === "MDN");
// 有同样的值
console.assert(clone.itself === clone);
// 循环引用被保留

4. 使用带标签的模板 (Tagged Template) 进行自定义解析

模板文字(template literals)或模板字符串(template strings)附带的一个好处是能够对它们进行标记。

这意味着开发者可以通过函数运行模板字符串,而不是让浏览器立即将该值分配给变量,从而可以控制实际字符串的生成方式。

标签模板(tag template)的工作方式是开发者只需创建一个函数,然后获取要针对字符串运行的函数的名称,最后只需将该函数名称放在模板前面即可:

function highlight(strings, ...values) {
  let str = "";
  strings.forEach((string, i) => {
    str += string + (values[i] || "");
    // 因为长度问题判空处理
  });
  return str;
}
const name = "Snickers";
const age = "100";
const sentence = highlight`My dog's name is ${name} and he is ${age} years old`;
console.log(sentence);
// 输出 My dog's name is Snickers and he is 100 years old

5. 使用 Symbols 作为 WeakMap 的键

在 WeakMap 中使用非全局 Symbols 作为键有助于保持内存效率且避免键重复,因为弱引用允许在不再需要对象时进行垃圾回收。

let mySymbol = Symbol("mySymbol");
let myWeakMap = new WeakMap();
myWeakMap.set(mySymbol, { name: "John"});

6. 使用生成器 Generators 实现高效的数据处理

生成器能够对异步编程进行细粒度的控制,非常适合处理大数据流。

async function* readFiles(directory) {
  const files = await fs.readdir(directory);
  for (const file of files) {
    const stats = await fs.stat(file);
    if (stats.isFile()) {
      yield {
        name: file,
        content: await fs.readFile(file, "utf8"),
      };
    }
  }
}

const files = readFiles(".");
console.log((await files.next()).value);
// 可能得输出: {name: 'file1.txt', content: '...'}
console.log((await files.next()).value);
// 可能得输出: {name: 'file2.txt', content: '...'}

async function* 声明会创建一个 AsyncGeneratorFunction 对象,其每次调用异步生成器函数时都会返回一个新的 AsyncGenerator 对象,该对象遵循异步迭代器协议。每次调用 next() 都会返回一个 Promise,该 Promise resolve 为迭代器的结果对象。

异步生成器函数结合了异步函数和生成器函数的特性,开发者可以在函数体中同时使用 await 和 yield 关键字,其中 await 以更符合工程学的方式处理异步任务,而 yield 能充分利用生成器函数的惰性执行特性。

7. 带有 # 的私有类字段

私有属性与常规的类属性相对应,后者是公共的,包括:类字段、类方法等。私有属性使用 # 前缀创建且不能在类外部合法引用,这些类属性的隐私封装由 JavaScript 本身强制执行。访问私有属性的唯一方法是通过点符号,并且只能在定义私有属性的类中进行访问。

在此语法出现之前,私有属性并非 JavaScript 的原生特性。在原型继承中,其行为可以用 WeakMap 对象或闭包来模拟,但在人机工程学方面,它们无法与 # 语法相提并论。

class ClassWithPrivate {
  #privateField;
  #privateFieldWithInitializer = 42;
  #privateMethod() {
    // …
  }
  static #privateStaticField;
  static #privateStaticFieldWithInitializer = 42;

  static #privateStaticMethod() {
    // …
  }
}

但是其依然有一些额外的语法限制:

  • 类中声明的所有私有标识符必须是唯一的,命名空间在静态属性和实例属性之间共享,除非两者都声明了 getter-setter 对
  • 私有标识符不能是 #constructor

8.Promise.allSettled() 用于处理多个 Promise

Promise.allSettled() 方法等待所有 Promise 完成,无论其状态如何都返回结果数组:

const promise1 = Promise.resolve(3);
const promise2 = new Promise((resolve, reject) =>
  setTimeout(reject, 100, "foo"),
);
const promises = [promise1, promise2];
Promise.allSettled(promises).then((results) =>
  results.forEach((result) => console.log(result.status)),
);
// 输出结果 "fulfilled"、"rejected"

9.globalThis 用于跨环境全局访问

globalThis 对象确保跨浏览器和 Node.js 等环境对全局上下文的访问保持一致:

console.log(globalThis === window);
// 判断是否是浏览器: true

10. 动态代理增强对象控制 JavaScript

Proxy 对象使开发者能够为另一个对象创建代理,该代理可以拦截并重新定义该对象的基本操作,例如:属性访问、赋值和方法调用。

const target = {
  message1: "hello",
  message2: "everyone",
};
const handler1 = {};
const proxy1 = new Proxy(target, handler1);
console.log(proxy1.message1);
// 输出 hello
console.log(proxy1.message2);
// 输出 everyone

参考资料

https://dev.to/jsdevspace/10-javascript-tips-to-boost-development-efficiency-2gno

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes/Private_properties

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Proxy

https://dev.to/roktim32/10-javascript-tips-and-tricks-244o

相关推荐

Node.js 获取文件信息及路径(node.js怎么获取当前文件路径)

获取文件信息每个文件都有一组细节,我们可以使用Node.js进行检查。特别是使用fs模块提供的stat()方法。constfs=require('fs');fs.stat(&#...

深入剖析JavaScript中深浅拷贝(js实现深浅拷贝)

大家好,我是Echa。最近有一位00后的小妹妹粉丝私信小编说自己很喜欢编程,目前在某公司实习前端开发工作,说到现在为止还没有搞懂JavaScript中深拷贝和浅拷贝这个问题,同时也在网上看了很多关于深...

为什么高手写 JS 总是又快又好?这10个技巧你要知道

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!JavaScript是前端开发的重要语言...

IT技术栈:Javascript神器,URL.createObjectURL()

URL.createObjectURL()是JavaScript中的一个方法,用于创建一个特殊的URL,该URL可以用于将不支持直接加载的数据(如二进制数据或Blob对象)嵌入到we...

如何在 Linux 中创建和管理组?(linux如何建立组)

在Linux中,组是用户账户的集合,用于统一管理权限。每个用户至少属于一个主组(PrimaryGroup),还可以加入多个附加组(SupplementaryGroup)。组的权限设置决定了用户对文...

付费文库内容无法复制,不用任何工具,学会这4种方法轻松复制

关注职场办公,分享实用干货,洞察科技资讯,这里是「职场科技范」。我们在搜索资料的时候,看到非常有用的文库,但往往都是付费的,只能看不能复制。今天就来教大家,学会下面这4种方法,轻松复制文库内容。一、内...

node.js v24.0.0 正式发布!10大重磅更新助力开发者,性能大幅提升

近日,Node.js官方团队正式发布了Node.jsv24.0.0版本,这是一个具有里程碑意义的重大更新。作为"Current"版本,它将在未来六个月内引领Node.js...

我理解的网站产品经理之四:网站产品前端姿势

来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。2016年了,嗨,大家新年好。作为一个网页的产品经理,网页的前端知识可谓是不能不知,本文主讲网站产品的前端姿势。通常,...

五一我要看七天小说!免费开源的轻量化书库talebook搭建流程。

这次来分享一个简单阅读项目:TaleBook,项目曾用名calibre-webserver。TaleBook是一个基于Calibre的简单的个人图书管理系统,支持在线阅读。不过鉴于各种规章制度,仅...

“5 分钟 CMake 使用指南,解决我的 C++ 打包问题!”

在软件开发的世界里,构建系统扮演着至关重要的角色,它不仅决定了项目的构建效率,还直接影响到团队协作的流畅度。对于许多C++开发者而言,CMake因其强大的功能和广泛的兼容性成为了构建自动化流程的...

大佬级鬼才终于把JavaScript整理成了修仙小说,让学习变简单

这是一本讲解JavaScript编程语言的技术书籍,只不过,本书采用了一种全新的写作手法。如果你厌倦了厚厚的、如同字典般的编程书籍,不妨尝试一下新的口味,话不多说,直接上干货!目录截图:内容展示:以上...

JavaScript基础知识点总结(javascript基础入门教程)

//逗比小憨憨/*第一章*HTML引用js方法:*1,外部引用:HTML外部引用js:<scriptsrc="js/day1.js"></script>*2,...

在Node.js中处理Zip文件(node运行js文件)

作者:疯狂的技术宅转发链接:https://mp.weixin.qq.com/s/edJd9-t1AyTGRcha_1k6RA前言Zip文件是常用的压缩文件格式。在本文中,我将演示如何用adm-...

Python 标准库中鲜为人知的宝藏 | Node.js 22.8.0 发布

Python标准库中鲜为人知的宝藏Python标准库功能强大,但有些模块却鲜为人知。本文将介绍一些有趣且实用的模块,助你提升代码效率和功能。数据结构:超越列表和字典除了常用的列表和字典,coll...

小程序,wxml页面里如何写JS代码?WXS如何模块化?

这篇接着上篇小程序,跳转页面的两种方式及其页面传参数继续讲,小程序wxml页面里如何写JS代码?wxs如何模块化?第一个问题:wxml页面要想类似HTML页面中写js代码,必须在页面中使用wxs标...