成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

30-seconds-code——browser

izhuhaodev / 788人閱讀

摘要:顯示所有指定的元素用操作符和清除所有指定元素的屬性。使用了兩個事件監(jiān)聽器。將指定的數(shù)組元素轉(zhuǎn)換成元素標(biāo)簽,然后將它們插入指定的選擇器元素內(nèi)用和去生成一個元素標(biāo)簽列表復(fù)制一個字符串到剪切板。用去執(zhí)行復(fù)制到剪切板。

英文文章來源于:https://github.com/Chalarangelo/30-seconds-of-code/blob/master/README.md

Browser currentURL

返回當(dāng)前頁面的 URL。

window.location.href 獲得當(dāng)前的 URL.

const currentURL = () => window.location.href;
// currentUrl() -> "https://google.com"
getURLParameters

返回一個包含當(dāng)前頁面 URL 的參數(shù)的對象.

match() 和一個合適的正則來獲得所有的鍵值對, 用Array.reduce() 去映射它們到一個對象內(nèi)。
location.search 獲得當(dāng)前 url 的參數(shù).

const getURLParameters = url =>
  url.match(/([^?=&]+)(=([^&]*))/g).reduce(
    (a, v) => (a[v.slice(0, v.indexOf("="))] = v.slice(v.indexOf("=") + 1), a), {}
  );
// getURLParameters("http://url.com/page?name=Adam&surname=Smith") -> {name: "Adam", surname: "Smith"}
redirect

重定向到一個指定的 URL.

window.location.hrefwindow.location.replace() 重定向 url
如果asLink 為 true,則模擬一個 鏈接單擊,否則為重定向。

const redirect = (url, asLink = true) =>
  asLink ? window.location.href = url : window.location.replace(url);
// redirect("https://google.com")
httpsRedirect

如果它當(dāng)前在HTTP中,將頁面重定向到HTTPS。另外,按后退按鈕不會將其返回到HTTP頁面,因為它在歷史中被替換了。

location.protocol 去獲得當(dāng)前所使用的協(xié)議。如果不是 HTTPS,用 location.replace() 將當(dāng)前頁轉(zhuǎn)換為使用 HTTPS 協(xié)議。用 location.href 去獲得鏈接地址,用 String.split() 移除當(dāng)前 URL的協(xié)議。

const httpsRedirect = () => {
  if(location.protocol !== "https:") location.replace("https://" + location.href.split("http://")[1]);
}
detectDeviceType

檢測網(wǎng)站是在移動設(shè)備,還是在桌面/筆記本上打開。

用一個正則表達式檢測 navigator.userAgent 屬性來判斷是移動設(shè)備還是桌面/筆記本。

const detectDeviceType = () =>
  /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)
    ? "Mobile"
    : "Desktop";
detectDeviceType(); // "Mobile" or "Desktop"
scrollToTop

平滑滾動到頁面頂部。

document.documentElement.scrollTopdocument.body.scrollTop 得到頁面滾動后的top值。
window.requestAnimationFrame() 去實現(xiàn)平滑滾動.

const scrollToTop = () => {
  const c = document.documentElement.scrollTop || document.body.scrollTop;
  if (c > 0) {
    window.requestAnimationFrame(scrollToTop);
    window.scrollTo(0, c - c / 8);
  }
};
// scrollToTop()
elementIsVisibleInViewport

如果指定的元素出現(xiàn)在可視窗口內(nèi),返回 true;否則,返回 false .

Element.getBoundingClientRect()window.inner(Width|Height) 的值來判斷給定元素是否在可視窗口內(nèi).
如果忽略第二個參數(shù)或者指定為 true 將判斷元素的部分出現(xiàn)在可是窗口內(nèi)。

const elementIsVisibleInViewport = (el, partiallyVisible = false) => {
  const { top, left, bottom, right } = el.getBoundingClientRect();
  const { innerHeight, innerWidth } = window;
  return partiallyVisible
    ? ((top > 0 && top < innerHeight) || (bottom > 0 && bottom < innerHeight)) &&
      ((left > 0 && left < innerWidth) || (right > 0 && right < innerWidth))
    : top >= 0 && left >= 0 && bottom <= innerHeight && right <= innerWidth;
};
// e.g. 100x100 viewport and a 10x10px element at position {top: -1, left: 0, bottom: 9, right: 10}
// elementIsVisibleInViewport(el) -> false (not fully visible)
// elementIsVisibleInViewport(el, true) -> true (partially visible)
bottomVisible

如果到達頁面可顯示區(qū)域的底部,返回 true ,否則返回 false .

scrollY, scrollHeightclientHeight 去判斷是否到達頁面可顯示區(qū)域底部.

const bottomVisible = () =>
  document.documentElement.clientHeight + window.scrollY >= (document.documentElement.scrollHeight || document.documentElement.clientHeight);
// bottomVisible() -> true
getScrollPosition

返回頁面滾動后的位置,也即是html文檔的卷起位置.

如果瀏覽器支持 pageXOffsetpageYOffset 就用它們;否則就用 scrollLeftscrollTop.
參數(shù) el 的默認值為 window.

const getScrollPosition = (el = window) =>
  ({x: (el.pageXOffset !== undefined) ? el.pageXOffset : el.scrollLeft,
    y: (el.pageYOffset !== undefined) ? el.pageYOffset : el.scrollTop});
// getScrollPosition() -> {x: 0, y: 200}
getStyle

返回指定元素屬性的css值。

Window.getComputedStyle() 去獲取指定元素的屬性值。

const getStyle = (el, ruleName) => getComputedStyle(el)[ruleName];
getStyle(document.querySelector("p"), "font-size"); // "16px"
hasClass

如果一個元素有指定的 class,返回 true ;否則,返回 false.

element.classList.contains() 去判斷一個元素是否有一個指定的class.

const hasClass = (el, className) => el.classList.contains(className);
hasClass(document.querySelector("p.special"), "special"); // true
toggleClass

切換一個元素的class。

element.classList.toggle() 去切換指定元素的class。

const toggleClass = (el, className) => el.classList.toggle(className);
toggleClass(document.querySelector("p.special"), "special"); // 這個段落將不再有 "special" class
setStyle

設(shè)置指定元素css樣式屬性的值.

element.style 設(shè)置指定元素的樣式 value。

const setStyle = (el, ruleName, value) => (el.style[ruleName] = value);
setStyle(document.querySelector("p"), "font-size", "20px"); // The first 

element on the page will have a font-size of 20px

hide

隱藏所有指定的元素。

用 spread (...) 操作符和 Array.forEach() 去給所有的指定元素添加 display: none 樣式 。

const hide = (...el) => [...el].forEach(e => (e.style.display = "none"));
hide(document.querySelectorAll("img")); // Hides all  elements on the page
show

顯示所有指定的元素

用spread (...) 操作符和 Array.forEach() 清除所有指定元素的 display 屬性。

const show = (...el) => [...el].forEach(e => (e.style.display = ""));
show(document.querySelectorAll("img")); // Shows all  elements on the page
speechSynthesis

語音合成 (實驗特性)

SpeechSynthesisUtterance.voicewindow.speechSynthesis.getVoices() 將一個消息轉(zhuǎn)換為語音.
window.speechSynthesis.speak() 播放消息.

更多詳情請參考 SpeechSynthesisUtterance interface of the Web Speech API.

const speechSynthesis = message => {
  const msg = new SpeechSynthesisUtterance(message);
  msg.voice = window.speechSynthesis.getVoices()[0];
  window.speechSynthesis.speak(msg);
};
speechSynthesis("Hello, World"); // // plays the message
onUserInputChange

不管什么時候用戶的input類型改變 (mouse or touch) 執(zhí)行這個函數(shù)。用于啟用/禁用依賴于輸入設(shè)備的代碼。這個過程是動態(tài)的,并于混合設(shè)備(例如:觸摸屏,筆記本)一起工作。

使用了兩個事件監(jiān)聽器。假如 mouse 輸入初始化,然后綁定一個 touchstart 時間將聽頁面。
依據(jù) touchstart 添加一個 mousemove 事件監(jiān)聽器,然后用 performance.now() 在20ms觸發(fā)兩次 mousemove 事件。
在這兩種情況下,執(zhí)行回調(diào)函數(shù)以input類型作為參數(shù)。

const onUserInputChange = callback => {
  let type = "mouse",
    lastTime = 0;
  const mousemoveHandler = () => {
    const now = performance.now();
    if (now - lastTime < 20)
      (type = "mouse"), callback(type), document.removeEventListener("mousemove", mousemoveHandler);
    lastTime = now;
  };
  document.addEventListener("touchstart", () => {
    if (type === "touch") return;
    (type = "touch"), callback(type), document.addEventListener("mousemove", mousemoveHandler);
  });
};

onUserInputChange(type => {
  console.log("The user is now using", type, "as an input method.");
});
UUIDGeneratorBrowser

在瀏覽器中生成UUID。

crypto API 生成一個 UUID, 可參考 RFC4122 v.4 。

const UUIDGeneratorBrowser = () =>
  ([1e7] + -1e3 + -4e3 + -8e3 + -1e11).replace(/[018]/g, c =>
    (c ^ (crypto.getRandomValues(new Uint8Array(1))[0] & (15 >> (c / 4)))).toString(16)
  );
UUIDGeneratorBrowser(); // "7982fcfe-5721-4632-bede-6000885be57d"
arrayToHtmlList

將指定的數(shù)組元素轉(zhuǎn)換成

  • 元素標(biāo)簽,然后將它們插入指定的id選擇器元素內(nèi).

    Array.map()document.querySelector() 去生成一個html元素標(biāo)簽列表.

    const arrayToHtmlList = (arr, listID) => arr.map(item => document.querySelector("#"+listID).innerHTML+=`
  • ${item}
  • `); // arrayToHtmlList(["item 1", "item 2"],"myListID")
    copyToClipboard

    復(fù)制一個字符串到剪切板。只用在用戶觸發(fā)事件時才會執(zhí)行 (i.e. 內(nèi)部用 click 事件監(jiān)聽)。

    創(chuàng)建一個