javascript史上最拽的玩法

  • 摘要:在JavaScript世界中,有些操作会让你无法理解,但是却无比优雅,如果你真正了解这些,BAT公司任你选。(文章后面有惊喜)

    一、5种方式实现值交换

    1. var temp = a; a = b; b = temp; (传统,但需要借助临时变量)2. a ^= b; b ^= a; a ^= b; (需要两个整数)3. b = [a, a = b][0] (借助数组)4. [a, b] = [b, a]; (ES6,解构赋值)5. a = a + b; b = a - b; a = a - b; (小学奥赛题)

    二、去掉小数部分

    parseInt(num)~~numnum >> 0num | 0

    三、判断 x 是否是整数

    function isInt(x) { return (x ^ 0) === x}// return Math.round(x) === x// return (typeof x === 'number') && (x % 1 === 0)// ES6 -> Number.isInteger()

    四、递归求阶乘

    function factorial(n) { return (n > 1) ? n * f(n - 1) : n}

    五、判断符号是否相同

    function sameSign(a, b) { return (a ^ b) >= 0}

    六、克隆数组

    arr.slice(0)

    七、数组去重

    // ES6Array.from(new Set(arr))// ES5arr.filter(function(ele, index, array){ return index===array.indexOf(ele)})

    八、数组最大值

    function maxArr(arr) { return Math.max.apply(null, arr)}

    九、数组最小值

    function minArr(arr) { return Math.min.apply(null, arr)}

    十、随机获取数组的一个成员

    function randomOne(arr) { return arr[Math.floor(Math.random() * arr.length)]}

    十一、产生随机颜色

    function getRandomColor() { return `#${Math.random().toString(16).substr(2, 6)}`}

    十二、随机生成指定长度的字符串

    function randomStr(n) { let standard = 'abcdefghijklmnopqrstuvwxyz9876543210' let len = standard.length let result = '' for (let i = 0; i < n; i++) { result += standard.charAt(Math.floor(Math.random() * len)) } return result}

    十三、深拷贝

    JSON.parse(JSON.stringify(obj))

    十四、打印出来看看

    console.log(([][[]] + [])[+!![]] + ([] + {})[!+[] + !![]])console.log((!(~+[]) + {})[--[~+''][+[]] * [~+[]] + ~~!+[]] + ({} + [])[[~!+[]] * ~+[]])

    十五、美化console

    console.info("%c哈哈", "color: #3190e8; font-size: 30px; font-family: sans-serif");

    javascript史上最拽的玩法

    文章下边有惊喜

    很有很多种神操作,如果大家有兴趣可以多多尝试一下。

  • 更多分享请关注,微信公众号:xiaohumuhe13,或今日头条号:(大话前端),还能获得海量视频资源哦~
  • 我的目标:做最好最全的前端资源分享 ​

转载于:https://my.oschina.net/jinsanpang/blog/1612095

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值