技术文摘
当下可用的 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 代码段 当下可用
- Vue 统计图表:时间序列与趋势拟合的优化策略
- 解决Vue warn Invalid prop invalid value错误的方法
- 寻找属性设置为true时,HTML中寻找活动进行时执行脚本
- HTML 中创建表格页脚的方法
- Vue 统计图插件使用教程与示例
- FabricJS:检查缓存脏状态与多边形是否需渲染器
- 用 CSS 设置文本行高
- JavaScript 中怎样从字符串创建哈希
- CSS用户选择属性解析
- 用 CSS 把对象颜色转为 256 级灰度
- Vue报错:无法正确使用v-model进行双向数据绑定的解决方法
- JavaScript程序查找矩阵中每一行的最大元素
- Vue框架中实现海量数据统计图表的方法
- Vue 处理图片缓存与预加载的方法
- Vue实现图片裂变与特效处理的方法