JavaScript 的奇技淫巧

JavaScript 作为一门动态语言,拥有丰富的特性和灵活性。这使得开发者们能够编写出既强大又高效的代码。然而,在某些情况下,为了追求代码的精简或性能优化,开发者可能会采用一些非传统的技巧。接下来,我们一起探索一些这样的"奇技淫巧",一起感受JavaScript的独特魅力。

1. 三元运算符的简洁写法

js 复制代码
const age = 25;
const message = age > 18 ? 'Adult' : 'Minor'; // 更简洁的条件赋值

2. 立即执行函数表达式 (IIFE)

js 复制代码
(function() {
    console.log('Immediately executed!');
})();

3. 函数柯里化 (Currying)

js 复制代码
function add(x) {
    return function(y) {
        return x + y;
    };
}

const addFive = add(5);
console.log(addFive(10)); // 15

4. 闭包 (Closure)

js 复制代码
function counter() {
    let count = 0;
    return function() {
        return ++count;
    };
}

const increment = counter();
console.log(increment()); // 1
console.log(increment()); // 2

5. 位运算

js 复制代码
// 检查一个数是否为2的幂
function isPowerOfTwo(n) {
    return n > 0 && (n & (n - 1)) === 0;
}

console.log(isPowerOfTwo(16)); // true

6. 字符串模板

js 复制代码
const name = 'Alice';
console.log(`Hello, ${name}!`); // Hello, Alice!

7. 箭头函数

js 复制代码
const multiply = (a, b) => a * b;
console.log(multiply(3, 4)); // 12

8. 解构赋值

js 复制代码
const person = { firstName: 'John', lastName: 'Doe' };
const { firstName, lastName } = person;
console.log(firstName, lastName); // John Doe

9. 扩展运算符

js 复制代码
const arr1 = [1, 2];
const arr2 = [3, 4];
const combined = [...arr1, ...arr2];
console.log(combined); // [1, 2, 3, 4]

10. 短路求值

js 复制代码
const a = null;
const b = 42;
console.log(a || b); // 42

11. 空值合并运算符 (??)

js 复制代码
const value = null;
const defaultVal = value ?? 5;
console.log(defaultVal); // 5

12. 可选链操作符 (?.)

js 复制代码
const obj = { nested: { value: 42 } };
console.log(obj.nested?.value); // 42
console.log(obj.missing?.value); // undefined

13. 递归

js 复制代码
function factorial(n) {
    return n <= 1 ? 1 : n * factorial(n - 1);
}
console.log(factorial(5)); // 120

14. 使用 Array.fromArray.of

js 复制代码
const arrayFromSet = Array.from(new Set([1, 2, 2, 3]));
console.log(arrayFromSet); // [1, 2, 3]

const arrayWithOneElement = Array.of(42);
console.log(arrayWithOneElement); // [42]

15. Promise 链式调用

js 复制代码
fetch('/api/data')
    .then(response => response.json())
    .then(data => console.log(data))
    .catch(error => console.error(error));

总结一下

这些技巧展示了 JavaScript 的灵活性和强大功能。虽然它们可以使代码变得更加紧凑和高效,但在实际开发中应该根据具体情况谨慎使用。始终记得,清晰和可维护的代码通常是首选。当你考虑使用这些技巧时,请确保它们不会影响到代码的整体可读性和可维护性。

相关推荐
小蜗牛慢慢爬行3 分钟前
有关异步场景的 10 大 Spring Boot 面试问题
java·开发语言·网络·spring boot·后端·spring·面试
Algorithm157613 分钟前
云原生相关的 Go 语言工程师技术路线(含博客网址导航)
开发语言·云原生·golang
shinelord明22 分钟前
【再谈设计模式】享元模式~对象共享的优化妙手
开发语言·数据结构·算法·设计模式·软件工程
Monly2129 分钟前
Java(若依):修改Tomcat的版本
java·开发语言·tomcat
boligongzhu30 分钟前
DALSA工业相机SDK二次开发(图像采集及保存)C#版
开发语言·c#·dalsa
Eric.Lee202130 分钟前
moviepy将图片序列制作成视频并加载字幕 - python 实现
开发语言·python·音视频·moviepy·字幕视频合成·图像制作为视频
7yewh32 分钟前
嵌入式Linux QT+OpenCV基于人脸识别的考勤系统 项目
linux·开发语言·arm开发·驱动开发·qt·opencv·嵌入式linux
长风清留扬34 分钟前
小程序毕业设计-音乐播放器+源码(可播放)下载即用
javascript·小程序·毕业设计·课程设计·毕设·音乐播放器
waicsdn_haha44 分钟前
Java/JDK下载、安装及环境配置超详细教程【Windows10、macOS和Linux图文详解】
java·运维·服务器·开发语言·windows·后端·jdk
_WndProc1 小时前
C++ 日志输出
开发语言·c++·算法