简短实用的JavaScript代码

1、数组去重
这是一个原生的JS函数但是非常简洁,Set接受任何可迭代对象,如数组[1,2,3,3],并删除重复项

// 数组去重
写法1 [...new Set(array)]
写法2 Array.from(new Set(array));

2、获取URL的查询参数
这个获取URL的查询参数代码,是我见过最精简的

写法1 Object.fromEntries(new URLSearchParams(location.search))
写法2 // 获取URL的查询参数
q={};location.search.replace(/([^?&=]+)=([^&]+)/g,(_,k,v)=>q[k]=v);q;

3、生成随机十六进制代码(生成随机颜色)
使用JavaScript简洁代码生成随机十六进制代码

// 生成随机十六进制代码 如:'#c618b2'
'#' + Math.floor(Math.random() * 0xffffff).toString(16).padEnd(6, '0');

4、返回一个键盘

// 用字符串返回一个键盘图形
(_=>[..."`1234567890-=~~QWERTYUIOP[]\\~ASDFGHJKL;'~~ZXCVBNM,./~"].map(x=>(o+=`/${b='_'.repeat(w=x<y?2:' 667699'[x=["BS","TAB","CAPS","ENTER"][p++]||'SHIFT',p])}\\|`,m+=y+(x+'    ').slice(0,w)+y+y,n+=y+b+y+y,l+=' __'+b)[73]&&(k.push(l,m,n,o),l='',m=n=o=y),m=n=o=y='|',p=l=k=[])&&k.join`
`)()

5、创建特定大小的数组

[...Array(3).keys()]
// [0, 1, 2]
Array.from({length: 3}, (item, index) => index)
// [0, 1, 2]

6、本地时间
通过一堆HTML,您可以创建一个本地时间,其中包含您可以一口气读出的源代码,它每秒都会用当前时间更新页面

// 创建本地时间
<body onload="setInterval(()=>document.body.innerHTML=new Date().toLocaleString().slice(10,19))"></body>

7、日历
创建过去七天的数组,如果将代码中的减号换成加号,你将得到未来7天的数组集合

// 创建过去七天的数组
[...Array(7).keys()].map(days => new Date(Date.now() - 86400000 * days));

8、生成随机ID
生成长度为11的随机字母数字字符串

// 生成长度为11的随机字母数字字符串
Math.random().toString(36).substring(2);

9、生成6位随机数

console.log(('000000' + Math.floor(Math.random() * 999999)).slice(-6));

10、大/小驼峰命名转下划线/连接符命名

'componentMapModelRegistry'.match(/^[a-z][a-z0-9]+|[A-Z][a-z0-9]*/g).join('_').toLowerCase();

11、地址栏参数转json

例如 key1=value1&key2=value2' 转换成json
export const query = (search = '') => ((querystring = '') => (q => (querystring.split('&').forEach(item => (kv => kv[0] && (q[kv[0]] = kv[1]))(item.split('='))), q))({}))(search.split('?')[1]);

12、16进制颜色代码生成

(function(){
return '#'+('00000'+(Math.random()*0x1000000<<0).toString(16)).slice(-6);
})()

13、从数组中找到符合条件的子数组

static find(query) {
    // this.all() 会取出数组中的所有数据
    return this.all().filter(item => Object.keys(query).every(key => item[key] === query[key]))
}

// 找出数组中所有 password 为 'password0' 以及 note 为 'note0' 的元素
const query = {
    password: 'password0',
    note: 'note0',
}
const users = User.find(query)
console.log('users', users)

14、随机字符串

Math.random().toString(16).substring(2) // 13位
Math.random().toString(36).substring(2) // 11位

15、论如何优雅的取整

var a = ~~2.33

var b= 2.33 | 0

var c= 2.33 >> 0

16、如何优雅的实现金钱格式化:1234567890 --> 1,234,567,890

用正则魔法实现:
var test1 = '1234567890'
var format = test1.replace(/\B(?=(\d{3})+(?!\d))/g, ',')

console.log(format) // 1,234,567,890
非正则的优雅实现:
function formatCash(str) {
return str.split('').reverse().reduce((prev, next, index) => {
return ((index % 3) ? next : (next + ',')) + prev
})
}
console.log(formatCash('1234567890')) // 1,234,567,890

还可以这样:
(123456789).toLocaleString()

17、论如何最佳的让两个整数交换数值

常规:
var a=1,b=2;
a += b;
b = a - b;
a -= b;

黑科技办法:

a ^= b;
b ^= a;
a ^= b;

ES6
[a, b]=[b, a]

其他小技巧:

随机数:
~~(Math.random()*1000) 比 Math.floor() 写起来简单多了。
判断奇偶:
222 % 2 == 0?"偶数":"奇数" 还可以写成 (222 & 1) == 0?"偶数":"奇数"
取最近的偶数:
(1111 | 1) - 1 结果为 1110,比写 if 判断奇偶再-1是不是更直接
除2取整:
最基础Math.floor(5/2),或者用第一个方法写为~~(5/2),最快的方法 5>>1,起码可以提高60%运行效率+26%编程效率
把数组中字符串改成首字母大写其他小写的:
return arr.map(name=>(name.split("").map((v,i)=>!i?v.toUpperCase():v.toLowerCase())).reduce((a,b)=>a+b))
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值