JavaScript騷操作

如有錯誤,歡迎批評指正!

技術無極限,唯一的限制是你的想象力!

在JavaScript世界中,有些操作會讓你無法理解,但是卻無比優雅。比如下面這些:

JavaScript騷操作

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 是否是整數

下面幾種方式都行

推薦下我的前端群:524262608,不管你是小白還是大牛,小編我都挺歡迎,不定期分享乾貨,包括我自己整理的一份2017最新的前端資料和零基礎入門教程,歡迎初學和進階中的小夥伴。

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騷操作

web前端學習方法經驗可以關注我的微信公眾號:‘學習web前端’,每天更新案例源碼或經驗分享,關注後回覆‘給我資料’可以領取一套完整的學習視頻

相關推薦

推薦中...