JavaScript精简代码集合

  • 日历

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

      JavaScript

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

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

      JavaScript

      // 生成长度为11的随机字母数字字符串
      Math.random().toString(36).substring(2);
      // hg7znok52x
  • 获取URL的查询参数

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

      JavaScript

      // 获取URL的查询参数
      q={};location.search.replace(/([^?&=]+)=([^&]+)/g,(_,k,v)=>q[k]=v);q;
  • 本地时间

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

      JavaScript

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

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

      JavaScript

      // 随机更改数组元素顺序,混淆数组
      (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简洁代码生成随机十六进制代码

      JavaScript

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

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

      JavaScript

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

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

      JavaScript

      // 数组去重
      [...new Set(arr)]
  • 创建特定大小的数组

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

      JavaScript

      [...Array(3).keys()]
      // [0, 1, 2]
  • 返回一个键盘 = =!

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

      JavaScript

      // 用字符串返回一个键盘图形
      (_=>[..."`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`
      `)()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端劝退师儿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值