技术文摘
当下可用的 10 个 JavaScript 代码段
2024-12-31 09:09:00 小编
当下可用的 10 个 JavaScript 代码段
在 JavaScript 的世界里,掌握一些实用的代码段可以极大地提高开发效率。以下为您介绍 10 个当下可用的 JavaScript 代码段。
- 数组去重
function uniqueArray(arr) {
return Array.from(new Set(arr));
}
- 数组扁平化
function flattenArray(arr) {
return arr.flat(Infinity);
}
- 检查对象是否为空
function isEmptyObject(obj) {
return Object.keys(obj).length === 0 && obj.constructor === Object;
}
- 生成随机字符串
function generateRandomString(length) {
let result = '';
const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
const charactersLength = characters.length;
for (let i = 0; i < length; i++) {
result += characters.charAt(Math.floor(Math.random() * charactersLength));
}
return result;
}
- 深拷贝对象
function deepCopy(obj) {
return JSON.parse(JSON.stringify(obj));
}
- 防抖函数
function debounce(func, delay) {
let timer;
return function (...args) {
clearTimeout(timer);
timer = setTimeout(() => {
func.apply(this, args);
}, delay);
};
}
- 节流函数
function throttle(func, delay) {
let lastCall = 0;
return function (...args) {
const now = new Date().getTime();
if (now - lastCall >= delay) {
func.apply(this, args);
lastCall = now;
}
};
}
- 格式化日期
function formatDate(date, format) {
const year = date.getFullYear();
const month = (date.getMonth() + 1).toString().padStart(2, '0');
const day = date.getDate().toString().padStart(2, '0');
const hours = date.getHours().toString().padStart(2, '0');
const minutes = date.getMinutes().toString().padStart(2, '0');
const seconds = date.getSeconds().toString().padStart(2, '0');
format = format.replace('YYYY', year);
format = format.replace('MM', month);
format = format.replace('DD', day);
format = format.replace('HH', hours);
format = format.replace('mm', minutes);
format = format.replace('ss', seconds);
return format;
}
- 简单的轮询函数
function poll(fn, delay, timeout) {
let timer;
let startTime = new Date().getTime();
function pollInternal() {
if (new Date().getTime() - startTime > timeout) {
clearTimeout(timer);
return;
}
const result = fn();
if (result) {
clearTimeout(timer);
return;
}
timer = setTimeout(pollInternal, delay);
}
pollInternal();
}
- 判断数据类型
function getType(obj) {
return Object.prototype.toString.call(obj).slice(8, -1);
}
这些代码段在实际开发中都非常实用,能够帮助您解决常见的问题,提高代码的质量和效率。希望您能将它们灵活运用到您的项目中,让开发工作更加轻松愉快。
TAGS: JavaScript 技术 代码示例 JavaScript 代码段 当下可用
- 熟悉 API 网关中 Lua-Resty 插件的方法
- Netty 与 ConnectionWatchdog 攻克客户端断连困境实战指南
- .NET 中 LINQ 神器:AsEnumerable、DefaultIfEmpty 与 Empty 用法大揭秘
- 阿里限流工具 Sentinel 的 17 个问题
- GitHub 上 Stars 最多的五大低代码平台,让低代码不再困扰!
- B站直播极速排障建设之全链路 Trace 追踪
- Supabase 平台工程策略的构建探讨
- 20 个 Python 字符串高效处理技法
- Python 十大经典项目及实战实例
- Springboot Starter 的工作原理
- 共同探讨技术文档编写之道
- 必知的八个常见前端开源库
- Spring Boot 项目性能优化技法
- 风控系统的完美设计(万能通用),超稳!
- SharpLab:.NET 反编译工具的技术剖析