js日历代码_教你如何用 JS 强行装逼,有些想都想不到

6cbcb4cc3f323f3ef195dba85d5e1fc4.png

文/北妈

阅读本文需要 3.5分钟

今天北妈来点收藏干货,以下代码部分来自网络总结,我们总追求简短有效的方式,有时候一行代码的奇技淫巧能带来很多代码篇幅减少
单行简洁的代码很难维护(有时甚至难以理解),但这并不能阻止广大攻城狮们脑洞,在编写简洁的代码后获得一定的满足感。

当然有的代码除了看起来装逼,并没有什么用,还增加了阅读难度。

原文: 12 Amazing JavaScript Shorthand Techniques

1. 空(null, undefined)验证

当我们创建了一个新的变量,我们通常会去验证该变量的值是否为空(null)或则未定义(undefined)。这对于 JavaScript 编程来说,是一个经常要考虑到的验证。

如果直接写,那么像下面这样:

if (variable1 !== null || variable1 !== undefined || variable1 !== "") { let variable2 = variable1;}

我们可以使用一个更加简洁的版本:

let variable2 = variable1 || "";

如果你不信,在谷歌浏览器开发者面板的控制台下试试!

2. 如何优雅的表示大数字

在 JavaScript 中,有一个简写数字的方法,也许你忽略了。1e7表示 10000000。

简化前:

for (let i = 0; i < 10000; i++) {

简化后:

for (let i = 0; i < 1e7; i++) {

3. 函数调用还可以更短

简化前:

function x() { console.log("x");}function y() { console.log("y");}let z = 3;if (z == 3) { x();} else { y();}

简化后:

function x() { console.log("x");}function y() { console.log("y");}let z = 3;(z == 3 ? x : y)();

你说四不四很短?

3.1. 另外一种undefined

var data = void 0; // undefined

4.论如何优雅的向下取整

var a = ~~2.33 //这种方法还可以将字符串转换成数字类型

var b= 2.33 | 0

var c= 2.33 >> 0

5.如何装逼用代码骂别人SB

(!(~+[])+{})[--[~+""][+[]]*[~+[]] + ~~!+[]]+({}+[])[[~!+[]]*~+[]]

6.如何用代码优雅的证明自己NB

([][[]]+[])[+!![]]+([]+{})[!+[]+!![]]


以下我最近的一些收藏 javascript精简代码集合。它们都可以在你的开发控制台中运行,你可以从控制台中查看运行结果。

作者:megatronhttps://juejin.im/post/5cc55eb5e51d456e577f93f0

1.日历

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

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

2.生成随机ID

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

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

3.获取URL的查询参数

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

?foo=bar&baz=bing => {foo: bar, baz: bing}

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

4.本地时间

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

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

5.数组混淆

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

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

6.生成随机十六进制代码(生成随机颜色)

使用JavaScript简洁代码生成随机十六进制代码

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

7.一个面试题

这是一个臭名昭著的面试题,让你写出他的运行结果,受不了~

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

8.数组去重

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

[...new Set(arr)]

9.创建特定大小的数组

方便快捷创建特定大小的数组

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

10.返回一个键盘(惊呆了)

这是一个很难看懂的简洁代码,但是运行后你会惊呆的,他竟然返回一个图形键盘

(_=>[..."`1234567890-=~~QWERTYUIOP[]\\~ASDFGHJKL;'~~ZXCVBNM,./~"].map(x=>(o+=`/${b='_'.repeat(w=x,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`

`)()

这是它的打印结果:

e82c9e4503eb3c21ec868a7318d5dbc5.png

惊呆不,不得不说有才的人真多!

每日金句“你如果认识从前的我,也许你会原谅现在的我。长的是磨难,短的是人生

热门阅读

月薪5k的国企, 和月薪2万的私企,我选国企

5分钟了解 凭啥Typescript 比JS还火

每天只想听你们说:小北最帅!

878284ed702b23881c1e7fb6d6dbcfe0.png

长按扫码关注我

前端你别闹

我觉得你们应该点 「在看」 281e14bfcb841b67cf4129daff275670.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值