快捷搜索:  汽车  科技

js的100个实用技巧(10个JS精简代码无形集合)

js的100个实用技巧(10个JS精简代码无形集合)Math.random().toString(36).substring(2); // 生成长度为11的随机字母数字字符串 [...Array(7).keys()].map(days => new Date(Date.now() - 86400000 * days)); 生成随机 ID在原型设计时需要经常使用创建 ID的功能,但是我在实际项目中看到有人使用,其实这相当不安全

js的100个实用技巧(10个JS精简代码无形集合)(1)

本文转载自微信公众号「小明菜市场」,作者小明菜市场。转载本文请联系小明菜市场公众号。

日历

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

// 创建过去七天的数组

[...Array(7).keys()].map(days => new Date(Date.now() - 86400000 * days));

生成随机 ID

在原型设计时需要经常使用创建 ID的功能,但是我在实际项目中看到有人使用,其实这相当不安全

// 生成长度为11的随机字母数字字符串

Math.random().toString(36).substring(2);

// hg7znok52x

获取 URL 的查询参数

获取URL中的查询参数。

// 获取URL的查询参数

q={};location.search.replace(/([^?&=] )=([^&] )/g (_ k v)=>q[k]=v);q;

获取本地时间

通过一堆js代码,可以获取到本地的时间

// 创建本地时间

<body onload="setInterval(()=>document.body.innerHTML=new Date().toLocaleString().slice(10 19))"></body>

数组混淆

用于随机更改数组中元素的顺序

// 随机更改数组元素顺序,混淆数组

(arr) => arr.slice().sort(() => Math.random() - 0.5)

/*

let a = (arr) => arr.slice().sort(() => Math.random() - 0.5)

let b = a([1 2 3 4 5])

console.log(b)

*/

生成随机的颜色

用于生成随机的颜色

// 生成随机十六进制代码 如:'#c618b2'

'#' Math.floor(Math.random() * 0xffffff).toString(16).padEnd(6 '0');

你知道这份代码运行的结果吗?

for(i=0; i<101;console.log(i%5?f||i:f 'Buzz'))f=i%3?'':'Fizz'

数组去重

使用原生的方法,使得数组去重

// 数组去重

[...new Set(arr)]

创建一个特定大小的数组

[...Array(3).keys()]

// [0 1 2]

这个返回什么?

你一定想不到,这个会返回一个键盘

// 用字符串返回一个键盘图形

(_=>[..."`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`

`)()

js的100个实用技巧(10个JS精简代码无形集合)(2)

猜您喜欢: