news 2026/4/27 22:11:13

JavaScript常用算法深度解析:从浏览器到Node.js的实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
JavaScript常用算法深度解析:从浏览器到Node.js的实战

目录

一、JavaScript算法设计的现代范式

1.1 JavaScript算法的演进革命

1.2 JavaScript算法的独特优势

二、数组与对象算法

2.1 现代数组操作方法

2.2 迭代器与生成器算法

三、排序与搜索算法

3.1 现代排序技术

3.2 高效搜索算法

四、性能优化与内存管理

4.1 算法性能优化技巧

4.2 数据缓存与记忆化

五、实用算法与设计模式

5.1 函数式编程实用算法

5.2 实用数据处理算法


如果您喜欢此文章,请收藏、点赞、评论,谢谢,祝您快乐每一天。

一、JavaScript算法设计的现代范式

1.1 JavaScript算法的演进革命

JavaScript算法设计经历了三次重大变革:

  • ES5时代:函数式编程萌芽(map、filter、reduce)
  • ES6时代:箭头函数、解构、Promise、模块化
  • ES2020+时代:可选链、空值合并、BigInt、动态导入

1.2 JavaScript算法的独特优势

// 1. 函数式编程的天然优势
const numbers = [1, 2, 3, 4, 5];

// 链式调用与组合
const result = numbers
.filter(n => n % 2 === 0) // [2, 4]
.map(n => n * 2) // [4, 8]
.reduce((sum, n) => sum + n, 0); // 12

// 2. 高阶函数与柯里化
const multiply = a => b => a * b;
const double = multiply(2);
const triple = multiply(3);

console.log(double(5)); // 10
console.log(triple(5)); // 15

// 3. 异步编程的优雅处理
async function processData(urls) {
const promises = urls.map(url => fetch(url).then(r => r.json()));
const results = await Promise.allSettled(promises);

return results
.filter(r => r.status === 'fulfilled')
.map(r => r.value);
}

二、数组与对象算法

2.1 现代数组操作方法

// 1. ES6+新增数组方法
const array = [1, 2, 3, 4, 5];

// find/findIndex - 查找元素
const firstEven = array.find(n => n % 2 === 0); // 2
const firstEvenIndex = array.findIndex(n => n % 2 === 0); // 1

// some/every - 条件检查
const hasEven = array.some(n => n % 2 === 0); // true
const allPositive = array.every(n => n > 0); // true

// flat/flatMap - 数组展平
const nested = [1, [2, [3, [4]]]];
const flattened = nested.flat(Infinity); // [1, 2, 3, 4]

const words = ["hello world", "good morning"];
const letters = words.flatMap(word => word.split(' '));
// ["hello", "world", "good", "morning"]

// 2. Array.from 与扩展运算符
// 类数组转数组
const nodeList = document.querySelectorAll('div');
const divArray = Array.from(nodeList);

// 创建范围数组
const range = (start, end) =>
Array.from({ length: end - start + 1 }, (_, i) => start + i);

console.log(range(1, 5)); // [1, 2, 3, 4, 5]

// 3. 使用Set和Map优化算法
// 数组去重
const duplicates = [1, 2, 2, 3, 4, 4, 5];
const unique = [...new Set(duplicates)]; // [1, 2, 3, 4, 5]

// 频率统计
function frequency(arr) {
return arr.reduce((map, item) => {
map.set(item, (map.get(item) || 0) + 1);
return map;
}, new Map());
}

// 4. 对象操作的高级技巧
// 对象合并与克隆
const obj1 = { a: 1, b: 2 };
const obj2 = { b: 3, c: 4 };

// 浅合并
const merged = { ...obj1, ...obj2 }; // { a: 1, b: 3, c: 4 }

// 深克隆(简单版)
const deepClone = obj => JSON.parse(JSON.stringify(obj));

// 动态属性名(计算属性)
const dynamicKey = 'score';
const student = {
name: 'Alice',
[dynamicKey]: 95,
[`${dynamicKey}Level`]: 'A'
};

// 可选链与空值合并
const user = {
profile: {
address: {
city: 'New York'
}
}
};

const city = user?.profile?.address?.city ?? 'Unknown';
const score = user?.scores?.[0] ?? 0;

2.2 迭代器与生成器算法

// 1. 自定义迭代器
class Range {
constructor(start, end, step = 1) {
this.start = start;
this.end = end;
this.step = step;
}

[Symbol.iterator]() {
let current = this.start;
const end = this.end;
const step = this.step;

return {
next() {
if (current <= end) {
const value = current;
current += step;
return { value, done: false };
}
return { done: true };
}
};
}
}

// 使用
for (const num of new Range(1, 5)) {
console.log(num); // 1, 2, 3, 4, 5
}

// 2. 生成器函数
function* fibonacci(limit) {
let [prev, curr] = [0, 1];

while (curr <= limit) {
yield curr;
[prev, curr] = [curr, prev + curr];
}
}

// 惰性求值
const fibSequence = fibonacci(100);
console.log([...fibSequence]); // [1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89]

// 3. 异步生成器
async function* asyncGenerator(urls) {
for (const url of urls) {
const response = await fetch(url);
yield response.json();
}
}

// 使用for await...of
(async () => {
const urls = ['/api/data1', '/api/data2'];

for await (const data of asyncGenerator(urls)) {
console.log(data);
}
})();

三、排序与搜索算法

3.1 现代排序技术

// 1. 内置排序的灵活使用
const items = [
{ name: 'Apple', price: 3.5, rating: 4.2 },
{ name: 'Banana', price: 2.0, rating: 4.5 },
{ name: 'Cherry', price: 5.0, rating: 4.0 }
];

// 多字段排序
items.sort((a, b) => {
// 先按价格升序,再按评分降序
if (a.price !== b.price) {
return a.price - b.price;
}
return b.rating - a.rating;
});

// 2. 稳定排序的实现
function stableSort(array, compare) {
return array
.map((item, index) => ({ item, index }))
.sort((a, b) => {
const result = compare(a.item, b.item);
return result === 0 ? a.index - b.index : result;
})
.map(({ item }) => item);
}

// 3. 使用Intl.Collator进行本地化排序
const germanWords = ['ä', 'z', 'a'];
germanWords.sort(new Intl.Collator('de').compare);
// ['a', 'ä', 'z']

// 4. 快速排序(函数式版本)
const quickSort = arr => {
if (arr.length <= 1) return arr;

const pivot = arr[0];
const left = arr.slice(1).filter(x => x <= pivot);
const right = arr.slice(1).filter(x => x > pivot);

return [...quickSort(left), pivot, ...quickSort(right)];
};

3.2 高效搜索算法

// 1. 二分查找(支持复杂比较)
function binarySearch(arr, target, compareFn = (a, b) => a - b) {
let left = 0;
let right = arr.length - 1;

while (left <= right) {
const mid = Math.floor((left + right) / 2);
const cmp = compareFn(arr[mid], target);

if (cmp === 0) return mid;
if (cmp < 0) left = mid + 1;
else right = mid - 1;
}

return -1;
}

// 2. 使用Map实现O(1)查找
class FastLookup {
constructor(items, keyFn = item => item.id) {
this.map = new Map();
this.keyFn = keyFn;

items.forEach(item => {
this.map.set(keyFn(item), item);
});
}

get(key) {
return this.map.get(key);
}

has(key) {
return this.map.has(key);
}
}

// 3. 模糊搜索(Levenshtein距离)
function levenshteinDistance(a, b) {
const matrix = Array(b.length + 1)
.fill()
.map(() => Array(a.length + 1).fill(0));

for (let i = 0; i <= a.length; i++) matrix[0][i] = i;
for (let j = 0; j <= b.length; j++) matrix[j][0] = j;

for (let j = 1; j <= b.length; j++) {
for (let i = 1; i <= a.length; i++) {
const cost = a[i - 1] === b[j - 1] ? 0 : 1;
matrix[j][i] = Math.min(
matrix[j][i - 1] + 1, // 删除
matrix[j - 1][i] + 1, // 插入
matrix[j - 1][i - 1] + cost // 替换
);
}
}

return matrix[b.length][a.length];
}

// 4. 使用Trie树进行前缀搜索
class TrieNode {
constructor() {
this.children = new Map();
this.isEndOfWord = false;
}
}

class Trie {
constructor() {
this.root = new TrieNode();
}

insert(word) {
let node = this.root;

for (const char of word) {
if (!node.children.has(char)) {
node.children.set(char, new TrieNode());
}
node = node.children.get(char);
}

node.isEndOfWord = true;
}

search(prefix) {
let node = this.root;

// 找到前缀的最后一个节点
for (const char of prefix) {
if (!node.children.has(char)) {
return [];
}
node = node.children.get(char);
}

// 收集所有以该前缀开头的单词
return this._collectWords(node, prefix);
}

_collectWords(node, prefix) {
const words = [];

if (node.isEndOfWord) {
words.push(prefix);
}

for (const [char, childNode] of node.children) {
words.push(...this._collectWords(childNode, prefix + char));
}

return words;
}
}

四、性能优化与内存管理

4.1 算法性能优化技巧

// 1. 使用Web Workers进行CPU密集型计算
// main.js
const worker = new Worker('worker.js');

worker.postMessage({ data: largeArray });
worker.onmessage = event => {
console.log('Result:', event.data);
};

// worker.js
self.onmessage = event => {
const result = heavyComputation(event.data.data);
self.postMessage(result);
};

// 2. 使用requestIdleCallback进行调度
function processInBackground(tasks) {
function processTask(deadline) {
while (tasks.length > 0 && deadline.timeRemaining() > 0) {
const task = tasks.shift();
executeTask(task);
}

if (tasks.length > 0) {
requestIdleCallback(processTask);
}
}

requestIdleCallback(processTask);
}

// 3. 使用WeakMap和WeakSet优化内存
// WeakMap的键是弱引用,不影响垃圾回收
const weakCache = new WeakMap();

function expensiveComputation(obj) {
if (weakCache.has(obj)) {
return weakCache.get(obj);
}

const result = /* 复杂计算 */;
weakCache.set(obj, result);
return result;
}

// 4. 防抖与节流优化
function debounce(fn, delay) {
let timer;

return function(...args) {
clearTimeout(timer);
timer = setTimeout(() => fn.apply(this, args), delay);
};
}

function throttle(fn, limit) {
let inThrottle;

return function(...args) {
if (!inThrottle) {
fn.apply(this, args);
inThrottle = true;
setTimeout(() => inThrottle = false, limit);
}
};
}

// 5. 使用位运算优化
// 判断奇偶
const isEven = n => (n & 1) === 0;

// 交换两个数(不使用临时变量)
let a = 5, b = 10;
a ^= b;
b ^= a;
a ^= b;

// 判断2的幂
const isPowerOfTwo = n => n > 0 && (n & (n - 1)) === 0;

4.2 数据缓存与记忆化

// 1. 记忆化函数(Memoization)
function memoize(fn) {
const cache = new Map();

return function(...args) {
const key = JSON.stringify(args);

if (cache.has(key)) {
return cache.get(key);
}

const result = fn.apply(this, args);
cache.set(key, result);
return result;
};
}

// 使用
const factorial = memoize(n => {
if (n <= 1) return 1;
return n * factorial(n - 1);
});

// 2. LRU缓存实现
class LRUCache {
constructor(capacity) {
this.capacity = capacity;
this.cache = new Map();
}

get(key) {
if (!this.cache.has(key)) return -1;

// 移动到最新位置
const value = this.cache.get(key);
this.cache.delete(key);
this.cache.set(key, value);

return value;
}

put(key, value) {
if (this.cache.has(key)) {
this.cache.delete(key);
} else if (this.cache.size >= this.capacity) {
// 删除最旧的项
const oldestKey = this.cache.keys().next().value;
this.cache.delete(oldestKey);
}

this.cache.set(key, value);
}
}

// 3. 使用Proxy实现智能缓存
function createCachedApi(apiFunction) {
const cache = new Map();

return new Proxy(apiFunction, {
apply(target, thisArg, args) {
const key = JSON.stringify(args);

if (cache.has(key)) {
console.log('Cache hit:', key);
return Promise.resolve(cache.get(key));
}

return target.apply(thisArg, args).then(result => {
cache.set(key, result);
return result;
});
}
});
}

五、实用算法与设计模式

5.1 函数式编程实用算法

// 1. 函数组合与管道
const compose = (...fns) => x => fns.reduceRight((acc, fn) => fn(acc), x);
const pipe = (...fns) => x => fns.reduce((acc, fn) => fn(acc), x);

// 使用
const add = x => y => x + y;
const multiply = x => y => x * y;
const square = x => x * x;

const compute = pipe(
add(5), // x + 5
multiply(2), // (x+5)*2
square // ((x+5)*2)^2
);

console.log(compute(3)); // ((3+5)*2)^2 = 256

// 2. 柯里化工具函数
const curry = fn => {
const arity = fn.length;

return function curried(...args) {
if (args.length >= arity) {
return fn.apply(this, args);
} else {
return (...moreArgs) => curried.apply(this, args.concat(moreArgs));
}
};
};

// 使用柯里化
const sum = curry((a, b, c) => a + b + c);
const add5 = sum(5);
const add5And10 = add5(10);

console.log(add5And10(15)); // 30

// 3. 惰性求值与无限序列
function* naturalNumbers() {
let n = 1;
while (true) {
yield n++;
}
}

// 获取前10个偶数
const first10Evens = [...naturalNumbers()]
.filter(n => n % 2 === 0)
.slice(0, 10);

// 4. Transducer(转换器)模式
const mapTransducer = fn => next => (acc, val) => next(acc, fn(val));
const filterTransducer = predicate => next => (acc, val) =>
predicate(val) ? next(acc, val) : acc;

const transduce = (transducer, reducer, initial, collection) => {
const transform = transducer(reducer);
return collection.reduce(transform, initial);
};

// 使用
const numbers = [1, 2, 3, 4, 5];
const xform = compose(
mapTransducer(x => x * 2),
filterTransducer(x => x > 5)
);

const result = transduce(xform, (acc, val) => [...acc, val], [], numbers);
// [6, 8, 10]

5.2 实用数据处理算法

// 1. 数据分组与聚合
function groupBy(array, keyFn) {
return array.reduce((groups, item) => {
const key = keyFn(item);
if (!groups[key]) groups[key] = [];
groups[key].push(item);
return groups;
}, {});
}

// 使用
const students = [
{ name: 'Alice', grade: 'A', subject: 'Math' },
{ name: 'Bob', grade: 'B', subject: 'Math' },
{ name: 'Charlie', grade: 'A', subject: 'Science' }
];

const bySubject = groupBy(students, s => s.subject);

// 2. 数据采样与分页
function paginate(array, pageSize, pageNumber) {
const start = (pageNumber - 1) * pageSize;
const end = start + pageSize;
return array.slice(start, end);
}

function reservoirSampling(array, k) {
const sample = array.slice(0, k);

for (let i = k; i < array.length; i++) {
const j = Math.floor(Math.random() * (i + 1));
if (j < k) {
sample[j] = array[i];
}
}

return sample;
}

// 3. 数据验证与清洗
const validators = {
required: value => value != null && value.toString().trim() !== '',
email: value => /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(value),
minLength: min => value => value.length >= min,
maxLength: max => value => value.length <= max,
pattern: regex => value => regex.test(value)
};

function validate(data, rules) {
const errors = {};

for (const [field, fieldRules] of Object.entries(rules)) {
for (const rule of fieldRules) {
if (!rule.validator(data[field])) {
errors[field] = rule.message;
break;
}
}
}

return errors;
}

// 4. 数据转换管道
class DataPipeline {
constructor() {
this.steps = [];
}

addStep(fn) {
this.steps.push(fn);
return this;
}

process(data) {
return this.steps.reduce((acc, step) => step(acc), data);
}
}

// 使用
const pipeline = new DataPipeline()
.addStep(data => data.filter(item => item.active))
.addStep(data => data.map(item => ({
...item,
score: item.points * item.multiplier
})))
.addStep(data => data.sort((a, b) => b.score - a.score))
.addStep(data => data.slice(0, 10));

如果您喜欢此文章,请收藏、点赞、评论,谢谢,祝您快乐每一天。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/19 1:17:16

计算机毕设java高校评优管理系统 基于Java的高校评优管理平台设计与实现 Java技术驱动的高校评优管理系统开发

计算机毕设java高校评优管理系统0u15n9&#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。 随着高校教育信息化的不断推进&#xff0c;传统的评优管理方式已经难以满足现代高校高效…

作者头像 李华
网站建设 2026/4/24 1:52:46

App项目后台如何用 XinServer 实现自动化测试?

App项目后台如何用 XinServer 实现自动化测试&#xff1f; 最近跟几个做移动端的朋友聊天&#xff0c;发现一个挺普遍的现象&#xff1a;大家花大把时间把App界面做得漂漂亮亮&#xff0c;交互丝滑流畅&#xff0c;但一到要对接后台、联调接口的时候&#xff0c;项目进度就肉眼…

作者头像 李华
网站建设 2026/4/27 13:32:36

微信记录2019(三)

有感今春四五次狂风大雨&#xff0c;世间之果实&#xff0c;非人为护之外&#xff0c;皆大浪淘沙之精华也&#xff01;06031103技术日益精进&#xff0c;身体日益减损&#xff0c;消瘦&#xff0c;沉重&#xff0c;易困乏&#xff0c;不易集中注意力&#xff0c;混混噩噩&#…

作者头像 李华
网站建设 2026/4/22 8:54:23

IDM最新详细安装+永久免费版教程,一次安装免费使用

下载地下 IDM下载地址集合 版本特点 反汇编免&#xff0c;启动即全功能&#xff0c;不再弹“假序列号”。 官方安装参数绿化&#xff0c;卸掉可选备份个人设置&#xff0c;升退自如。 简体语言补全&#xff0c;新增字串全翻译&#xff0c;界面无英文死角。 去每日提示、禁联…

作者头像 李华
网站建设 2026/4/20 0:48:17

JLink烧录器使用教程:STM32 SWD接口通信问题全面讲解

以下是对您提供的博文内容进行 深度润色与结构重构后的技术文章 。我以一位资深嵌入式系统工程师兼教学博主的身份&#xff0c;彻底摒弃模板化表达、AI腔调和教科书式罗列&#xff0c;转而采用 真实开发现场的语言节奏、问题驱动的逻辑脉络、经验沉淀的技术判断 &#xff0…

作者头像 李华
网站建设 2026/4/23 14:23:50

GLM-TTS采样率设置影响有多大?实测告诉你

GLM-TTS采样率设置影响有多大&#xff1f;实测告诉你 你有没有遇到过这样的情况&#xff1a;明明用了同一段参考音频、同样的文本&#xff0c;只改了一个参数&#xff0c;生成的语音听起来却一个“像真人说话”&#xff0c;另一个“像电子闹钟报时”&#xff1f;这个关键变量&…

作者头像 李华