🧙‍​​♂️ 9 个 JavaScript 技巧和窍门,让你像巫师一样编程

2025-05-28

🧙‍​​♂️ 9 个 JavaScript 技巧和窍门,让你像巫师一样编程

1. 生成一定范围内的数字

在某些情况下,我们需要创建一个包含数字范围的数组。比如说,生日输入框就需要包含这个范围。以下是最简单的实现方法。

let start = 1900,
    end = 2000;
[...new Array(end + 1).keys()].slice(start);
// [ 1900, 1901, ..., 2000]

// also this, but more unstable results for big range
Array.from({ length: end - start + 1 }, (_, i) => start + i);
Enter fullscreen mode Exit fullscreen mode

2. 使用数组作为函数的参数

有时你需要将值收集到数组中,然后将其作为函数的参数传递。在 ES6 中,你只需使用展开运算符 (...) 即可从中提取数组。[arg1, arg2] > (arg1, arg2)

const parts = {
  first: [0, 2],
  second: [1, 3],
};

["Hello", "World", "JS", "Tricks"].slice(...parts.second);
// ["World", "JS", "Tricks"]
Enter fullscreen mode Exit fullscreen mode

您可以将其与任何功能一起使用

3. 使用值作为数学方法的参数

所以,我们擅长将值展开并放入函数中。当我们需要在数组中找出数字的 Math.max 或 Math.min 时,可以像下面这样操作。

// Find the highest element's y position is 474px
const elementsHeight =  [...document.body.children].map(
  el => el.getBoundingClientRect().y
);
Math.max(...elementsHeight);
// 474

const numbers = [100, 100, -1000, 2000, -3000, 40000];
Math.min(...numbers);
// -3000
Enter fullscreen mode Exit fullscreen mode

4. 在数组中合并/展平数组

Array 有一个很棒的方法,叫做Array.flat,它需要深度作为参数,你需要将其展平(default: 1)。但是如果你不知道深度,你需要将其全部展平。我们只需将其Infinity作为参数即可。此外,还有一个很棒的flatMap方法。

const arrays = [[10], 50, [100, [2000, 3000, [40000]]]];
arrays.flat(Infinity);
// [ 10, 50, 100, 2000, 3000, 40000 ]
Enter fullscreen mode Exit fullscreen mode

5. 防止代码崩溃

代码中出现不可预测的行为并不好,但如果有,就需要处理它。

例如。常见的错误是TypeError,如果您尝试获取 undefined/null 等属性。

注意:如果你的项目不支持可选链式调用,请使用它

const found = [{ name: "Alex" }].find(i => i.name === 'Jim');
console.log(found.name);
// TypeError: Cannot read property 'name' of undefined
Enter fullscreen mode Exit fullscreen mode

你可以这样避免

const found = [{ name: "Alex" }].find(i => i.name === 'Jim') || {};
console.log(found.name);
// undefined
Enter fullscreen mode Exit fullscreen mode

当然,这取决于具体情况,但对于小问题来说,这是可以的。你不需要编写大量代码来处理它。

6. 传递参数的好方法

一个很好的例子是styled-components,在 ES6 中,你可以将模板字面量作为函数的参数传递,而无需使用括号。如果你正在实现格式化/转换文本的函数,这是一个不错的技巧。

const makeList = (raw) =>
  raw
    .join()
    .trim()
    .split("\n")
    .map((s, i) => `${i + 1}. ${s}`)
    .join("\n");

makeList`
Hello, World
Hello, World
`;
// 1. Hello
// 2. World
Enter fullscreen mode Exit fullscreen mode

7. 像巫师一样交换变量

使用解构赋值语法我们可以轻松交换变量。

let a = "hello";
let b = "world";

// Wrong
a = b
b = a
// { a: 'world', b: 'world' }

// Correct
[a, b] = [b, a];
// { a: 'world', b: 'hello' }
Enter fullscreen mode Exit fullscreen mode

错误方法的解决方案是添加第三个临时变量:(

8.按字母顺序排序

我曾在很多跨国公司工作过,他们的应用程序中包含非英语数据。当你用那些“绝妙”的技巧对这类数据列表进行排序时,结果看起来可能还不错,有时是因为当时只有几个字符串。也可能是因为你不了解该语言的字母表。
请使用正确的字母表,确保数据按该语言的字母顺序排序。

例如,德语字母表

// Wrong
["a", "z", "ä"].sort((a, b) => a - b);
// ['a', 'z', 'ä']

// Correct
["a", "z", "ä"].sort((a, b) => a.localeCompare(b));
// [ 'a', 'ä', 'z' ]
Enter fullscreen mode Exit fullscreen mode

9. 好好掩盖

最后一个技巧是关于屏蔽字符串。当你需要屏蔽任何变量时。当然不是密码 :) 这只是一个例子。我们只需获取字符串的一部分substr(-3),从其末尾开始 3 个字符,并用任意符号填充剩余的长度(示例*

const password = "hackme";
password.substr(-3).padStart(password.length, "*");
// ***kme
// Hmmm I guess your first attempts might be wrong
Enter fullscreen mode Exit fullscreen mode

结论

尽量写出简洁美观的代码。保存所有你想在代码中使用的技巧,并跟踪 JavaScript 的变更日志。

祝大家开发愉快!🎉

在 GitHub上保存并贡献技巧/窍门,就像代码一样

文章来源:https://dev.to/orkhanjafarovr/9-javascript-tips-tricks-to-code-like-a-wizard-559i
PREV
在 VSCode 中撰写 DEV 文章有什么想法吗?💬
NEXT
如何解压由 All-in-one-Wp-Migration Wordpress 插件创建的 .wpress 存档文件