亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

javascript史上最拽的玩法

標簽:
Html5 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)
~~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");
點擊查看更多內容
17人點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
Web前端工程師
手記
粉絲
193
獲贊與收藏
758

關注作者,訂閱最新文章

閱讀免費教程

感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消