欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

4個值得收藏的Javascript技巧

 更新時間:2022年07月29日 08:52:17   作者:??天行無忌???  
這篇文章主要介紹了4個值得收藏的Javascript技巧,文章首先通過變量轉字符串展開主題詳情,需要的小伙伴可以參考一下

前言

學習一門語言的一種非常有效的方法就是閱讀該編程語言開發(fā)的優(yōu)秀開源項目的源代碼。 Vuejs是最好的Javascript開源項目之一。

1.變量轉字符串

vue/src/shared/util.js

將值轉換為字符串是一個非常常見的需求,在Javascript中,有兩個函數(shù)將值轉換為字符串:

  • String()
  • JSON.stringify()

這兩個功能具有不同的機制,請看下面代碼:

console.log(String(null)); // null
console.log(JSON.stringify(null)); // null

console.log(String(undefined)); // undefined 這里是字符串
console.log(JSON.stringify(undefined)); // undefined 這里是變量

console.log(String("abc")); // abc
console.log(JSON.stringify("abc")); // "abc"

console.log(String({ key: "value" })); // [object Object]
console.log(JSON.stringify({ key: "value" })); // {"key":"value"}

console.log(String([1, 2, 3])); // 1,2,3
console.log(JSON.stringify([1, 2, 3])); // [1,2,3]

const obj = {
    title: "devpoint",
    toString() {
        return "obj";
    },
};
console.log(String(obj)); // obj
console.log(JSON.stringify(obj)); // {"title":"devpoint"}

從上面輸出結果來看,兩個方法將對象轉為字符串機制存在差異,如何選擇呢?

  • 實際開發(fā)中我們需要將nullundefined轉換為字符串時,經(jīng)常是希望它返回一個空字符串。
  • 當需要將一個數(shù)組和一個普通對象轉換為字符串時,經(jīng)常使用JSON.stringify。
  • 如果需要對象的toString方法被重寫,則需要使用String()。
  • 在其他情況下,使用String()將變量轉換為字符串。

為了滿足以上條件,Vue源碼的實現(xiàn)如下:

function isPlainObject(obj) {
    return Object.prototype.toString.call(obj) === "[object Object]";
}
function toString(val) {
    if (val === null || val === undefined) return "";
    if (Array.isArray(val)) return JSON.stringify(val);
    if (isPlainObject(val) && val.toString === Object.prototype.toString)
        return JSON.stringify(val);
    return String(val);
}
const obj = {
    title: "devpoint",
    toString() {
        return "obj";
    },
};
console.log(toString(obj)); // obj
console.log(toString([1, 2, 3])); // [1, 2, 3]
console.log(toString(undefined)); // ""
console.log(toString(null)); // ""

2.普通對象

vue/src/shared/util.js

Object.prototype.toString允許將對象轉換為字符串。對于普通對象,當調(diào)用此方法時,總是返回[object object]。

const runToString = (obj) => Object.prototype.toString.call(obj);
console.log(runToString({})); // [object Object]
console.log(runToString({ title: "devpoint" })); // [object Object]
console.log(runToString({ title: "devpoint", author: { name: "devpoint" } })); // [object Object]

類似上面這種對象我們稱之為普通對象。

在Javascript中還有一些特殊的對象,如Array、StringRegExp,它們在Javascript引擎中具有特殊的設計。當它們調(diào)用Object.prototype.toString方法時,會返回不同的結果。

const runToString = (obj) => Object.prototype.toString.call(obj);
console.log(runToString(["devpoint", 2021])); // [object Array]
console.log(runToString(new String("devpoint"))); // [object String]
console.log(runToString(/devpoint/)); // [object RegExp]

為了區(qū)分特殊設計對象和普通對象,可以用下面的函數(shù)來實現(xiàn)。

function isPlainObject(obj) {
    return Object.prototype.toString.call(obj) === "[object Object]";
}

很多時候,我們希望一個函數(shù)只執(zhí)行一次。如果多次調(diào)用該函數(shù),則只會執(zhí)行第一次。

3.once

vue/src/shared/util.js

很多時候,我們希望一個函數(shù)只執(zhí)行一次。如果多次調(diào)用該函數(shù),則只會執(zhí)行第一次。

function once(fn) {
    let called = false;
    return function () {
        if (!called) {
            called = true;
            fn.apply(this, arguments);
        }
    };
}

function launchRocket() {
    console.log("我已經(jīng)執(zhí)行了");
}
const launchRocketOnce = once(launchRocket);
launchRocketOnce();
launchRocketOnce();
launchRocketOnce();

4.瀏覽器嗅探

vue/src/core/util/env.js

我們知道Javascript可以在瀏覽器、nodejs等環(huán)境中運行,那么如何檢查當前的Javascript代碼是否在瀏覽器環(huán)境中運行?

如果Javascript在瀏覽器環(huán)境中運行,則會有一個全局對象:window。因此,可以通過以下方式判斷環(huán)境:

const inBrowser = typeof window !== "undefined";

在Chrome中執(zhí)行

在Node中執(zhí)行

如果腳本在瀏覽器環(huán)境中運行,那么我們可以通過以下方式獲取瀏覽器的userAgent

const UA = inBrowser && window.navigator.userAgent.toLowerCase();

在Chrome中執(zhí)行

不同的瀏覽器具有不同的userAgent。在Internet Explorer的userAgent中,始終包含單詞MSIETrident。在Chrome瀏覽器的userAgent中,始終包含Chrome一詞。

同樣,在Android操作系統(tǒng)瀏覽器中,userAgent始終包含單詞Android。在iOS中,總是有iPhone、iPad、iPod、iOS一詞。

因此,可以通過檢查userAgent來確定當前的瀏覽器供應商和操作系統(tǒng)。

export const UA = inBrowser && window.navigator.userAgent.toLowerCase();
export const isIE = UA && /msie|trident/.test(UA);
export const isIE9 = UA && UA.indexOf("msie 9.0") > 0;
export const isEdge = UA && UA.indexOf("edge/") > 0;
export const isAndroid =  (UA && UA.indexOf("android") > 0) || weexPlatform === "android";
export const isIOS =  (UA && /iphone|ipad|ipod|ios/.test(UA)) || weexPlatform === "ios";
export const isChrome = UA && /chrome\/\d+/.test(UA) && !isEdge;
export const isPhantomJS = UA && /phantomjs/.test(UA);
export const isFF = UA && UA.match(/firefox\/(\d+)/);

附帶說明一下,Edge和Chrome均基于Chromium,因此兩種瀏覽器的userAgent都包含Chrome一詞。也就是說,當瀏覽器的userAgent中包含Chrome一詞時,該瀏覽器不一定是Chrome。const isChrome = UA && /chrome\/\d+/.test(UA) && !isEdge

到此這篇關于4個值得收藏的Javascript技巧的文章就介紹到這了,更多相關Javascript技巧內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 使用原生JS實現(xiàn)滾輪翻頁效果的示例代碼

    使用原生JS實現(xiàn)滾輪翻頁效果的示例代碼

    這篇文章主要介紹了使用原生JS實現(xiàn)滾輪翻頁效果的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05
  • JavaScript實現(xiàn)簡單打地鼠游戲

    JavaScript實現(xiàn)簡單打地鼠游戲

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)簡單打地鼠游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 怎樣用JS模擬實現(xiàn)枚舉

    怎樣用JS模擬實現(xiàn)枚舉

    這篇文章主要介紹了怎樣用JS模擬實現(xiàn)枚舉,對枚舉感興趣的同學,可以實驗一下
    2021-04-04
  • JS如何修改對象數(shù)組的key值

    JS如何修改對象數(shù)組的key值

    這篇文章主要介紹了JS如何修改對象數(shù)組的key值,使用map循環(huán),在map循環(huán)內(nèi)創(chuàng)建一個新對象,將item要改變的key賦給新創(chuàng)建的對象里面新key值,然后push給一個新創(chuàng)建的數(shù)組dataNew即可,需要的朋友可以參考下
    2024-02-02
  • JavaScript中的遍歷詳解(多種遍歷)

    JavaScript中的遍歷詳解(多種遍歷)

    編程這么多年,要是每次寫遍歷代碼時都用 for 循環(huán),真心感覺對不起 JavaScript 語言,這篇文章為大家分享幾種不同的遍歷方法,需要的朋友可以參考下
    2017-04-04
  • TypeScript函數(shù)和類型斷言實例詳解

    TypeScript函數(shù)和類型斷言實例詳解

    在某些情況下,我們會比TS更清楚一個數(shù)據(jù)的類型,這種時候我們就可以使用斷言來告訴TS相信我,我知道自己在干什么,下面這篇文章主要給大家介紹了關于TypeScript函數(shù)和類型斷言的相關資料,需要的朋友可以參考下
    2022-06-06
  • jQuery $.data()方法使用注意細節(jié)

    jQuery $.data()方法使用注意細節(jié)

    前段時間同事在群里對jQuery里的.data()方法大發(fā)牢騷,接下來介紹jQuery $.data()方法使用注意細節(jié),需要了解的朋友可以參考下
    2012-12-12
  • JavaScript.The.Good.Parts閱讀筆記(一)假值與===運算符

    JavaScript.The.Good.Parts閱讀筆記(一)假值與===運算符

    JavaScript 假值與===運算符,學習js的朋友可以看下。
    2010-11-11
  • Textarea輸入字數(shù)限制實例(兼容iOS&安卓)

    Textarea輸入字數(shù)限制實例(兼容iOS&安卓)

    下面小編就為大家?guī)硪黄猅extarea輸入字數(shù)限制實例(兼容iOS&安卓)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • D3.js實現(xiàn)簡潔實用的動態(tài)儀表盤的示例

    D3.js實現(xiàn)簡潔實用的動態(tài)儀表盤的示例

    本篇文章主要介紹了D3.js實現(xiàn)簡潔實用的動態(tài)儀表盤的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04

最新評論