js骚操作 - 秀出一片新天地

前言

如有错误,欢迎批评指正!

技术无极限,唯一的限制是你的想象力!

在JavaScript世界中,有些操作会让你无法理解,但是却无比优雅。比如下面这些:

 

五种方法实现值交换

下面几种方式都行

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)

~~num

num >> 0

num | 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)

 

数组去重

// ES6

Array.from(new Set(arr))



// ES5

arr.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");

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值