日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
八種酷炫JavaScript 技巧

1.檢查元素是否在屏幕可見(jiàn)區(qū)域內(nèi)

我們?nèi)绾潍@得元素的點(diǎn)擊率?

主要取決于用戶點(diǎn)擊元素的次數(shù)和元素在頁(yè)面上顯示的次數(shù)。

我們可以很容易地獲取到用戶的點(diǎn)擊次數(shù),但是如何獲取一個(gè)元素的顯示次數(shù)呢?

我們可以通過(guò)IntersectionObserver輕松實(shí)現(xiàn),大家可以點(diǎn)擊codepen體驗(yàn)一下實(shí)際效果。

box is visible
box

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

我們經(jīng)常使用 lodash 來(lái)深拷貝一個(gè)對(duì)象。

const obj = {
  a: {
    b: {
      name: 'fatfish'
    }
  }
}


const obj2 = lodash.cloneDeep(obj)


obj2.a.b.name = 'medium'
console.log(obj.a.b.name) // fatfish
console.log(obj2.a.b.name) // medium

但這非常麻煩,因?yàn)槲覀儽仨毾螺d整個(gè)庫(kù)才能使用 cloneDeep。

幸運(yùn)的是,在大多數(shù)情況下,我們可以使用這兩種更簡(jiǎn)單的方式來(lái)深拷貝一個(gè)對(duì)象。

深度克隆1

const deepClone1 = (obj) => {
  return JSON.parse(JSON.stringify(obj))
}


const obj = {
  a: {
    b: {
      name: 'fatfish'
    }
  }
}
const obj2 = deepClone1(obj)
obj2.a.b.name = 'medium'
console.log(obj.a.b.name) // fatfish
console.log(obj2.a.b.name) // medium

是的,我相信你已經(jīng)看到了,deepClone1 有一些缺陷,它不能復(fù)制函數(shù)、正則表達(dá)式、未定義等值。

const deepClone1 = (obj) => {
  return JSON.parse(JSON.stringify(obj))
}


const obj = {
  a: {
    b: {
      name: 'fatfish'
    }
  },
  reg: /fatfish/gi,
  name: undefined,
  showName: (name) => console.log(name)
}
const obj2 = deepClone1(obj)
console.log(obj2)
/*
{
    "a": {
        "b": {
            "name": "fatfish"
        }
    },
    "reg": {}
}
*/

深度克隆2

另一種方法是使用 structuredClone。

這非常方便,我們甚至可以不做任何處理就可以深拷貝一個(gè)對(duì)象。

它甚至可以復(fù)制正則表達(dá)式和未定義的。

const obj = {
  a: {
    b: {
      name: 'fatfish'
    }
  },
  reg: /fatfish/gi,
  name: undefined,
}


const obj2 = structuredClone(obj)
obj2.a.b.name = 'medium'
console.log(obj.a.b.name) // fatfish
console.log(obj2.a.b.name) // medium
console.log(obj2)
/*
{
    "a": {
        "b": {
            "name": "medium"
        }
    },
    "reg": /fatfish/gi,
    "name": undefined
}
*/

但是真的沒(méi)有缺點(diǎn)嗎? 它在某些情況下也無(wú)法正常工作。

  • 它不能復(fù)制功能
  • 它不復(fù)制dom元素
  • ETC。

3.獲取瀏覽器名稱(chēng)

在前端監(jiān)控系統(tǒng)中,需要獲取用戶出錯(cuò)的瀏覽器。

這是獲取主要瀏覽器名稱(chēng)的通用函數(shù)。

const getBrowserName = () => {
  const userAgent = window.navigator.userAgent
  const browsers = {
    chrome: /chrome/i,
    safari: /safari/i,
    firefox: /firefox/i,
    ie: /internet explorer/i,
    edge: /edge/i,
    opera: /opera|opr/i,
    yandex: /yandex/i,
    uc: /ucbrowser/i,
    samsung: /samsungbrowser/i,
    maxthon: /maxthon/i,
    phantomjs: /phantomjs/i,
    crios: /crios/i,
    firefoxios: /fxios/i,
    edgios: /edgios/i,
    safariios: /safari/i,
    android: /android/i,
    ios: /(iphone|ipad|ipod)/i,
    unknown: /unknown/i
  }


  for (const key in browsers) {
    if (browsers[key].test(userAgent)) {
      return key
    }
  }
  return 'unknown'
}
// Execute the above code in chrome browser
console.log(getBrowserName()) // chrome
// Execute the above code in safari browser
console.log(getBrowserName()) // safari

4.獲取隨機(jī)顏色

我怎樣才能得到一個(gè)隨機(jī)的有效顏色?

大家可以點(diǎn)擊codepen鏈接體驗(yàn)實(shí)際效果。

const randomColor = () => {
  // Generate three random numbers as the three components of an RGB color value
  const r = Math.floor(Math.random() * 256);
  const g = Math.floor(Math.random() * 256);
  const b = Math.floor(Math.random() * 256);
  // Convert RGB color values to hexadecimal format
  const hexR = r.toString(16).padStart(2, '0');
  const hexG = g.toString(16).padStart(2, '0');
  const hexB = b.toString(16).padStart(2, '0');
  // Concatenated into a complete color value string
  const hexColor = `#${hexR}${hexG}${hexB}`;
  return hexColor;
}

演示地址:https://codepen.io/qianlong/pen/qBJaOGO

5.復(fù)制內(nèi)容到剪貼板

為了給我們的網(wǎng)站用戶提供更好的交互體驗(yàn),我們經(jīng)常需要提供將內(nèi)容復(fù)制到剪貼板的功能。

難以置信的是,我們竟然只需要6行代碼就可以實(shí)現(xiàn)這個(gè)功能。

const copyToClipboard = (content) => {
  const textarea = document.createElement("textarea")
  textarea.value = content
  document.body.appendChild(textarea)
  textarea.select()
  document.execCommand("Copy")
  textarea.remove()
}


copyToClipboard('i love medium') // i love medium

演示地址:https://codepen.io/qianlong/pen/PoyGZYO

6.從搜索中獲取查詢字符串

使用 URLSearchParams 解析搜索數(shù)據(jù)變得非常容易。

const getSearchParam = (name) => {
  const searchParams = new URLSearchParams(window.location.search)
  return searchParams.get(name)
}


// https://medium.com?name=fatfish&age=1000
console.log(getSearchParam('name')) // fatfish
console.log(getSearchParam('age')) // 1000
const getSearchParams = () => {
  const searchParams = new URLSearchParams(window.location.search)
  const params = {};
  for (const [ key, value ] of searchParams) {
    params[key] = value
  }


  return params
}
// https://medium.com?name=fatfish&age=1000
getSearchParams() // { name: 'fatfish', age: 1000 }

7.將元素滾動(dòng)到頁(yè)面頂部

我們可以使用 scrollIntoView 方法將元素滾動(dòng)到頁(yè)面頂部。

甚至它可以提供非常流暢的用戶體驗(yàn)。

const scrollToTop = (ele) => {
  ele.scrollIntoView({ behavior: "smooth", block: "start" })
}


document.querySelector('button').addEventListener('click', function () {
  scrollToTop(this)
}, false)

8.將元素滾動(dòng)到頁(yè)面底部

哇,太好了,將元素滾動(dòng)到頂部是如此簡(jiǎn)單。

朋友們,如何將元素滾動(dòng)到頁(yè)面底部?我想你已經(jīng)猜到了,設(shè)置block結(jié)束即可。

const scrollToTop = (ele) => {
  ele.scrollIntoView({ behavior: "smooth", block: "end" })
}


document.querySelector('button').addEventListener('click', function () {
  scrollToTop(this)
}, false)

演示地址:https://codepen.io/qianlong/pen/mdzrVGK

總結(jié)

以上就是我這篇文章想與您分享的8個(gè)關(guān)于JavaScript的技巧,希望對(duì)您有用。


新聞名稱(chēng):八種酷炫JavaScript 技巧
網(wǎng)站URL:http://m.5511xx.com/article/djpijpg.html