国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

TypeScript 中的類型檢查實用函數(shù)

這篇具有很好參考價值的文章主要介紹了TypeScript 中的類型檢查實用函數(shù)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

TypeScript 中的類型檢查實用函數(shù)

一、概述

在前端開發(fā)中,我們經(jīng)常需要判斷變量的類型以進(jìn)行相應(yīng)的操作或處理。TypeScript 提供了基礎(chǔ)的類型檢查,但有時我們需要更復(fù)雜或更靈活的類型檢查。這篇博客文章將介紹一組實用函數(shù),用于各種常見的類型檢查。文章來源地址http://www.zghlxwxcb.cn/news/detail-685596.html

二、代碼實現(xiàn)

// 禁用一些 ESLint 規(guī)則,主要是因為下面使用了 Object.prototype 的方法
// eslint-disable-next-line @typescript-eslint/unbound-method
const { toString } = Object.prototype

// 判斷一個值是否為指定類型
export function is(val: unknown, type: string) {
  return toString.call(val) === `[object ${type}]`
}

// 判斷一個值是否已定義
export function isDef<T = unknown>(val?: T): val is T {
  return typeof val !== 'undefined'
}

// 判斷一個值是否未定義
export function isUnDef<T = unknown>(val?: T): val is T {
  return !isDef(val)
}

// 判斷一個值是否是對象
export function isObject(val: any): val is Record<any, any> {
  return val !== null && is(val, 'Object')
}

// 判斷一個值是否為空
export function isEmpty<T = unknown>(val: T): val is T {
  if (isArray(val) || isString(val)) return val.length === 0
  if (val instanceof Map || val instanceof Set) return val.size === 0
  if (isObject(val)) return Object.keys(val).length === 0
  return false
}

// 判斷一個值是否是日期對象
export function isDate(val: unknown): val is Date {
  return is(val, 'Date')
}

// 判斷一個值是否是 null
export function isNull(val: unknown): val is null {
  return val === null
}

// 判斷一個值是否是 null 或 undefined
export function isNullOrUnDef(val: unknown): val is null | undefined {
  return isUnDef(val) || isNull(val)
}

// 判斷一個值是否是數(shù)字
export function isNumber(val: unknown): val is number {
  return is(val, 'Number')
}

// 判斷一個值是否是 Promise
export function isPromise<T = any>(val: unknown): val is Promise<T> {
  return is(val, 'Promise') && isObject(val) && isFunction(val.then) && isFunction(val.catch)
}

// 判斷一個值是否是字符串
export function isString(val: unknown): val is string {
  return is(val, 'String')
}

// 判斷一個值是否是函數(shù)
export function isFunction(val: unknown): val is Function {
  return typeof val === 'function'
}

// 判斷一個值是否是布爾值
export function isBoolean(val: unknown): val is boolean {
  return is(val, 'Boolean')
}

// 判斷一個值是否是正則表達(dá)式
export function isRegExp(val: unknown): val is RegExp {
  return is(val, 'RegExp')
}

// 判斷一個值是否是數(shù)組
export function isArray(val: any): val is Array<any> {
  return !!val && Array.isArray(val)
}

// 判斷一個值是否是 Window 對象
export function isWindow(val: any): val is Window {
  return typeof window !== 'undefined' && is(val, 'Window')
}

// 判斷一個值是否是 DOM 元素
export function isElement(val: unknown): val is Element {
  return isObject(val) && !!val.tagName
}

// 判斷一個值是否是 Map 對象
export function isMap(val: unknown): val is Map<any, any> {
  return is(val, 'Map')
}

// 判斷當(dāng)前環(huán)境是否是服務(wù)器
export const isServer = typeof window === 'undefined'

// 判斷當(dāng)前環(huán)境是否是客戶端
export const isClient = !isServer

// 判斷一個字符串是否是有效的 URL
export function isUrl(path: string): boolean {
  const reg = /^((https|http|ftp|rtsp|mms):\/\/)(([0-9a-zA-Z_!~*'().&=+$%-]+: )?[0-9a-zA-Z_!~*'().&=+$%-]+@)?(([0-9]{1,3}.){3}[0-9]{1,3}|([0-9a-zA-Z_!~*'()-]+.)*([0-9a-zA-Z][0-9a-zA-Z-]{0,61})?[0-9a-zA-Z].[a-zA-Z]{2,6})(:[0-9]{1,4})?((\/?)|(\/[0-9a-zA-Z_!~*'().;?:@&=+$,%#-]+)+\/?)$/
  return reg.test(path)
}

到了這里,關(guān)于TypeScript 中的類型檢查實用函數(shù)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進(jìn)行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • typeScript中的函數(shù)類型

    目錄 1.函數(shù)聲明 2.函數(shù)表達(dá)式 3.用接口定義函數(shù)的形狀 4.可選參數(shù) 5.參數(shù)默認(rèn)值 ?6.剩余參數(shù) 7.重載 函數(shù)是JavaScript應(yīng)用程序的基礎(chǔ)。它幫助你實現(xiàn)抽象層, 模擬類,信息隱藏和模塊。在TypeScript里, 雖然已經(jīng)支持類,命名空間和模塊,但函數(shù)仍然是主要的定義行為的地方。

    2024年02月03日
    瀏覽(29)
  • 【TypeScript】TS條件類型(十)

    【TypeScript】TS條件類型(十)

    ?? 個人主頁: 不叫貓先生 ???♂? 作者簡介:2022年度博客之星前端領(lǐng)域TOP 2,前端領(lǐng)域優(yōu)質(zhì)作者、阿里云專家博主,專注于前端各領(lǐng)域技術(shù),共同學(xué)習(xí)共同進(jìn)步,一起加油呀! ??優(yōu)質(zhì)專欄:vue3從入門到精通、TypeScript從入門到實踐 ?? 資料領(lǐng)?。呵岸诉M(jìn)階資料以及文中源

    2023年04月11日
    瀏覽(22)
  • 【TypeScript】TS類型聲明(二)

    【TypeScript】TS類型聲明(二)

    ??個人主頁: 不叫貓先生 ???♂?作者簡介:前端領(lǐng)域新星創(chuàng)作者、華為云享專家、阿里云專家博主,專注于前端各領(lǐng)域技術(shù),共同學(xué)習(xí)共同進(jìn)步,一起加油呀! ??系列專欄:vue3從入門到精通、TypeScript從入門到實踐 ??個人簽名:不破不立 TypeScript從入門到實踐專欄 是博

    2024年01月20日
    瀏覽(25)
  • 【TypeScript】TS類型守衛(wèi)(六)

    【TypeScript】TS類型守衛(wèi)(六)

    ??個人主頁: 不叫貓先生 ???♂?作者簡介:前端領(lǐng)域優(yōu)質(zhì)創(chuàng)作者、阿里云專家博主,專注于前端各領(lǐng)域技術(shù),共同學(xué)習(xí)共同進(jìn)步,一起加油呀! ??系列專欄:vue3從入門到精通、TypeScript從入門到實踐 ??個人簽名:不破不立 ??資料領(lǐng)取:前端進(jìn)階資料以及文中源碼可以

    2024年02月22日
    瀏覽(23)
  • TypeScript:為什么JavaScript需要類型檢查?

    JavaScript是當(dāng)今最為流行的編程語言之一。它是一種高級的、解釋性的編程語言,用于Web應(yīng)用程序的開發(fā)。然而,JavaScript的靈活性也是它的弱點之一。JavaScript中的變量、函數(shù)、類等都是動態(tài)類型,這意味著它們的類型可以在運(yùn)行時發(fā)生變化。雖然這種靈活性為JavaScript開發(fā)人員

    2024年02月04日
    瀏覽(21)
  • 【TypeScript】TS類型斷言-類型的聲明和轉(zhuǎn)換(五)

    【TypeScript】TS類型斷言-類型的聲明和轉(zhuǎn)換(五)

    ??個人主頁: 不叫貓先生 ???♂?作者簡介:前端領(lǐng)域新星創(chuàng)作者、華為云享專家、阿里云專家博主,專注于前端各領(lǐng)域技術(shù),共同學(xué)習(xí)共同進(jìn)步,一起加油呀! ??系列專欄:vue3從入門到精通、TypeScript從入門到實踐 ??個人簽名:不破不立 ??資料領(lǐng)?。呵岸诉M(jìn)階資料以

    2024年02月22日
    瀏覽(23)
  • 【TypeScript】TS接口interface類型(三)

    【TypeScript】TS接口interface類型(三)

    一、前言 TypeScript的核心原則之一是對值所具有的結(jié)構(gòu)進(jìn)行類型檢查。 它有時被稱做“鴨式辨型法”或“結(jié)構(gòu)性子類型化”。 在TypeScript里,接口的作用就是為這些類型命名和為你的代碼或第三方代碼定義契約。這些方法都應(yīng)該是抽象的,需要由具體的類去實現(xiàn),然后第三方

    2024年02月14日
    瀏覽(31)
  • TypeScript基礎(chǔ)篇 - TS日常類型 上篇

    目錄 TS的常見用法介紹 ?example01.ts 逃避類型檢查:any 思考一下~:不知道類型 類型標(biāo)注 函數(shù)(參數(shù)和返回值) 匿名函數(shù) TS如何知道匿名函數(shù)的類型? TS是一種標(biāo)注式語言,不侵入JS的設(shè)計 文章內(nèi)容 基礎(chǔ)類型、數(shù)組 any/unkown 類型標(biāo)注 函數(shù) 對象類型 聯(lián)合 別名 接口 斷言 字面

    2024年02月16日
    瀏覽(24)
  • 前端TypeScript學(xué)習(xí)day01-TS介紹與TS部分常用類型

    前端TypeScript學(xué)習(xí)day01-TS介紹與TS部分常用類型

    (創(chuàng)作不易,感謝有你,你的支持,就是我前行的最大動力,如果看完對你有幫助,請留下您的足跡) 目錄 TypeScript 介紹 TypeScript 是什么 TypeScript 為什么要為 JS 添加類型支持?? TypeScript 相比 JS 的優(yōu)勢? TypeScript 初體驗? 安裝編譯 TS 的工具包 編譯并運(yùn)行 TS 代碼 簡化運(yùn)行 TS

    2024年02月08日
    瀏覽(22)
  • 前端TypeScript學(xué)習(xí)day02-TS常用類型

    前端TypeScript學(xué)習(xí)day02-TS常用類型

    (創(chuàng)作不易,感謝有你,你的支持,就是我前行的最大動力,如果看完對你有幫助,請留下您的足跡) 目錄 TypeScript 常用類型 接口? 元組? 類型推論 類型斷言 字面量類型 枚舉 any 類型 typeof? 當(dāng)一個對象類型被多次使用時,一般會使用接口(interface)來描述對象的類型,達(dá)到

    2024年02月08日
    瀏覽(28)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包