成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

11 種有用的 JavaScript 技巧

開(kāi)發(fā) 前端
今天這篇文章,我想與你分享 11個(gè)有用JavaScript技巧,這些技巧可以大大提高你的工作效率。

今天這篇文章,我想與你分享 11個(gè)有用JavaScript技巧,這些技巧可以大大提高你的工作效率。

1、生成隨機(jī)顏色的兩種方式

1).generateRandomHexColor

const generateRandomHexColor = () => {
  return `#${Math.floor(Math.random() * 0xffffff).toString(16).padStart(6, '0')}`
}


generateRandomHexColor() // #a8277c
generateRandomHexColor() // #09c20c
generateRandomHexColor() // #dbc319

2).生成隨機(jī)RGBA

const generateRandomRGBA = () => {
  const r = Math.floor(Math.random() * 256)
  const g = Math.floor(Math.random() * 256)
  const b = Math.floor(Math.random() * 256)
  const a = Math.random().toFixed(2) 


  return `rgba(${[ r, g, b, a ].join(',')})`
}
generateRandomRGBA() // rgba(242,183,70,0.21)
generateRandomRGBA() // rgba(65,171,97,0.72)
generateRandomRGBA() // rgba(241,74,149,0.33)

2、復(fù)制內(nèi)容到剪貼板的兩種方式

方式1

const copyToClipboard = (text) => navigator.clipboard && navigator.clipboard.writeText && navigator.clipboard.writeText(text)


copyToClipboard('hello medium')

方式2

const copyToClipboard = (content) => {
  const textarea = document.createElement("textarea")


  textarea.value = content
  document.body.appendChild(textarea)
  textarea.select()
  document.execCommand("Copy")
  textarea.remove()
}


copyToClipboard('hello medium')

3.獲取URL中的查詢(xún)參數(shù)

const parseQuery = (name) => {
  return new URL(window.location.href).searchParams.get(name)
}


// https://medium.com?name=fatfish&age=100
parseQuery('name') // fatfish
parseQuery('age') // 100
parseQuery('sex') // null

4.Please wait for a while

const timeout = (timeout) => new Promise((rs) => setTimeout(rs, timeout))

5.打亂數(shù)組

const shuffle = (array) => array.sort(() => 0.5 - Math.random())


shuffle([ 1, -1, 2, 3, 0, -4 ]) // [2, -1, -4, 1, 3, 0]
shuffle([ 1, -1, 2, 3, 0, -4 ]) // [3, 2, -1, -4, 0, 1]

6.深拷貝一個(gè)對(duì)象

如何深拷貝一個(gè)對(duì)象?使用 structuredClone 使它變得非常容易。

const obj = {
  name: 'fatfish',
  node: {
    name: 'medium',
    node: {
      name: 'blog'
    }
  }
}


const cloneObj = structuredClone(obj)
cloneObj.name = '1111'
cloneObj.node.name = '22222'
console.log(cloneObj)
/*
{
    "name": "1111",
    "node": {
        "name": "22222",
        "node": {
            "name": "blog"
        }
    }
}
*/
console.log(obj)
/*
{
    "name": "fatfish",
    "node": {
        "name": "medium",
        "node": {
            "name": "blog"
        }
    }
}
*/

7.確保一個(gè)元素在可見(jiàn)區(qū)域內(nèi)

前段時(shí)間在工作中遇到了一個(gè)很麻煩的需求,感謝IntersectionObserver的幫助,可以很方便的檢測(cè)出一個(gè)元素是否在可見(jiàn)區(qū)域。

const isElInViewport = (el) => {
  return new Promise(function(resolve) {
    const observer = new IntersectionObserver((entries) => {
      entries.forEach((entry) => {
        if (entry.target === el) {
          resolve(entry.isIntersecting)
        }
      })
    })


    observer.observe(el)
  })
}


const inView = await isElInViewport(document.body)
console.log(inView) // true

8.獲取當(dāng)前選中的文本

許多翻譯網(wǎng)站都有此功能,可以在其中選擇一段文字并將其翻譯成其他國(guó)家/地區(qū)的語(yǔ)言。

const getSelectedContent = () => window.getSelection().toString()

9.獲取所有瀏覽器cookie

可以很方便的幫我們獲取瀏覽器中的cookie信息

const getAllCookies = () => {
  return document.cookie.split(";").reduce(function(cookieObj, cookie) {
    const cookieParts = cookie.split("=")
    cookieObj[cookieParts[0].trim()] = cookieParts[1].trim()
    return cookieObj
  }, {})
}


getAllCookies() 
/*
{
    "_ga": "GA1.2.496117981.1644504126",
    "lightstep_guid/medium-web": "bca615c0c0287eaa",
    "tz": "-480",
    "nonce": "uNIhvQRF",
    "OUTFOX_SEARCH_USER_ID_NCOO": "989240404.2375598",
    "sz": "2560",
    "pr": "1",
    "_dd_s": "rum"
}
*/

10.刪除指定名稱(chēng)的cookie

我們只能刪除沒(méi)有 HttpOnly 標(biāo)志的 cookie,我的朋友。

const clearCookie = (name) => {
  document.cookie = name + "=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;";
}


clearCookie('_ga') // _ga is removed from the cookie

11.將多維數(shù)組轉(zhuǎn)換為一維數(shù)組

雖然我們通過(guò)遞歸函數(shù)將多維數(shù)組轉(zhuǎn)換為一維數(shù)組,但是有一個(gè)非常簡(jiǎn)單的方法可以解決這個(gè)問(wèn)題。

const flatten = (array) => {
  return array.reduce((result, it) => {
    return result.concat(Array.isArray(it) ? flatten(it) : it)
  }, [])
}


const arr = [
  1,
  [
    2,
    [
      3,
      [
        4,
        [
          5,
          [
            6
          ]
        ]
      ]
    ]
  ]
]
console.log(flatten(arr)) // [1, 2, 3, 4, 5, 6]

秘訣是使用數(shù)組的平面方法。

const arr = [
1,
  [
2,
    [
3,
      [
4,
        [
5,
          [
6
          ]
        ]
      ]
    ]
  ]
]
console.log(arr.flat(Infinity)) // [1, 2, 3, 4, 5, 6]

總結(jié)

以上就是我今天想與你分享的全部?jī)?nèi)容,希望這些內(nèi)容能夠?qū)δ阌兴鶐椭?/p>

責(zé)任編輯:華軒 來(lái)源: web前端開(kāi)發(fā)
相關(guān)推薦

2024-08-20 15:23:27

JavaScript開(kāi)發(fā)

2023-05-18 15:32:02

HTML開(kāi)發(fā)技巧

2022-12-25 16:03:31

JavaScript技巧

2022-12-22 14:44:06

JavaScript技巧

2023-07-18 07:56:31

工具reduce業(yè)務(wù)

2023-06-28 00:02:40

2020-06-21 13:57:21

JavaScript開(kāi)發(fā)代碼

2022-05-30 09:44:11

TypeScriptJavaScript技巧

2023-09-07 16:28:46

JavaScrip

2019-12-02 18:45:38

JavaScript開(kāi)發(fā)數(shù)組

2023-05-22 15:35:10

JavaScriptWeb開(kāi)發(fā)

2023-10-26 07:47:35

JavaScript代碼變量

2022-11-28 23:44:26

JavaScript技巧程序員

2020-01-06 09:41:28

JavaScript瀏覽器工具

2023-04-26 15:27:11

JavaScript技巧元素

2020-05-17 16:19:59

JavaScript代碼開(kāi)發(fā)

2023-06-13 15:15:02

JavaScript前端編程語(yǔ)言

2009-12-08 10:38:51

Windows 7操作

2023-09-06 16:55:33

JavaScript閉包

2009-09-03 11:23:54

Eclipse技巧
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 99久久婷婷| 性高湖久久久久久久久3小时 | 精品一区二区三 | 日韩有码一区 | 久久国产一区二区 | 免费黄色的视频 | 中文日韩在线视频 | 久久99成人 | 久久国产精品免费一区二区三区 | 久久激情视频 | 精品国产欧美一区二区 | 精品久久久一区 | 超碰精品在线 | 天天弄天天操 | 91精品国产欧美一区二区 | 成人国产综合 | 精品久久久久久久久亚洲 | 日韩精品一区二区三区免费观看 | 欧美一区二区三区国产 | 看一级毛片视频 | 米奇7777狠狠狠狠视频 | 亚洲激情在线观看 | 亚洲毛片 | 免费观看av | 一区二区三区四区不卡 | 黄色一级大片在线免费看产 | 黄色毛片一级 | 久久一本| 亚洲色图综合网 | 久久国产精品免费一区二区三区 | 国产在线视频99 | 国产一区二区三区免费观看在线 | 在线观看亚洲专区 | 欧州一区二区三区 | 国产成人精品免费视频大全最热 | 久久成人免费观看 | 欧美h版| 亚洲一区二区三区乱码aⅴ 四虎在线视频 | 一级片在线观看视频 | 国产ts人妖另类 | 免费毛片www com cn |