Кроме тринокулярной операции, какие еще позы вы знаете? оставить сообщение~~
Единственную строчку лаконичного кода сложно поддерживать (иногда даже трудно понять), но это не мешает подавляющему большинству осадных львов думать и получать определенное удовлетворение после написания лаконичного кода.
Вот некоторые из моих последних фаворитовjavascript
Сжатый набор кода. Все они могут быть запущены в вашей консоли разработки, и вы можете просматривать результаты из консоли. А пока, я надеюсь, вы поделитесь некоторыми из своих коллекций в комментариях!
календарь
Создайте массив за последние семь дней, если заменить минус в коде на плюс, то получится коллекция массивов за следующие семь дней
// 创建过去七天的数组
[...Array(7).keys()].map(days => new Date(Date.now() - 86400000 * days));
Создать случайный идентификатор
Функция создания идентификатора часто используется при прототипировании. Но я видел людей, использующих его в реальных проектах. На самом деле это не безопасно
// 生成长度为11的随机字母数字字符串
Math.random().toString(36).substring(2);
// hg7znok52x
Получить параметры запроса URL
Этот код параметра запроса для получения URL-адреса является самым кратким, который я когда-либо видел.QAQ
?foo=bar&baz=bing => {foo: bar, baz: bing}
// 获取URL的查询参数
q={};location.search.replace(/([^?&=]+)=([^&]+)/g,(_,k,v)=>q[k]=v);q;
местное время
С кучей HTML вы можете создать локальное время с исходным кодом, который вы можете прочитать за один раз, и он будет обновлять страницу с текущим временем каждую секунду.
// 创建本地时间
<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)
*/
Генерировать случайные шестнадцатеричные коды (генерировать случайные цвета)
Сгенерируйте случайный шестнадцатеричный код, используя краткий код JavaScript
// 生成随机十六进制代码 如:'#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'
Дедупликация массива
Это нативная функция JS, но очень лаконичная. Set принимает любой итерируемый объект, такой как массив [1,2,3,3], и удаляет дубликаты.
// 数组去重
[...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`
`)()
Вот его распечатка:
удивительный!