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

JavaScript常用工具函數(shù)庫匯總

 更新時間:2020年09月17日 08:38:08   作者:大明的IT筆記  
業(yè)務(wù)中比較常用的JavaScript工具函數(shù),可以用在前端環(huán)境,也可以用在node服務(wù)端,統(tǒng)一整理,方便查閱,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下

對象或數(shù)組的深拷貝

/**
 * 對象或數(shù)組的深拷貝
 * @param {*} cloneObj 被克隆的對象
 * @param {*} targetObj 克隆的目標對象
 * @param {*} isOverride 若屬性重復(fù),是否覆蓋被克隆對象的屬性
 */
function deepClone(cloneObj, targetObj, isOverride = true) {
 const _toString = Object.prototype.toString
 if (_toString.call(cloneObj) !== '[object Array]' && _toString.call(cloneObj) !== '[object Object]') {
  return cloneObj
 }
 var cloneTarget = _toString.call(cloneObj) === '[object Array]' ? [] : {}
 for (let key in cloneObj) {
  if (Object.prototype.hasOwnProperty.call(cloneObj, key)) {
   if (_toString.call(cloneObj[key]) === '[object Array]' || _toString.call(cloneObj[key]) === '[object Object]') {
    cloneTarget[key] = deepClone(cloneObj[key])
   } else {
    cloneTarget[key] = cloneObj[key]
   }
  }
 }
 if (targetObj && (_toString.call(cloneObj) === _toString.call(targetObj))) {
  //這里要注意,克隆的目標對象也要deepClone下
  cloneTarget = isOverride
   ? Object.assign(cloneTarget, deepClone(targetObj))
   : Object.assign(deepClone(targetObj), cloneTarget)
 }
 return cloneTarget
}

精準判斷數(shù)據(jù)類型

//精準判斷數(shù)據(jù)類型
function getVerifyDataTypes() {
 const types = ["String", "Number", "Boolean", "Null", "Undefined", "Function", "Object", "Array", "Date", "Error", "RegExp", "Symbol", "Map", "Set"]
 let Type = {}
 // 示例用法:Type.isString('javascript')
 for (let i = 0; i < types.length; i++) {
  Type[`is${types[i]}`] = obj => Object.prototype.toString.call(obj) === `[object ${types[i]}]`
 }
 // 判斷字符串是否為json格式
 Type.isJsonStr = str => {
  if (typeof str == 'string') {
   try {
    let obj = JSON.parse(str);
    if (obj && typeof obj == 'object') {
     return true;
    }
    return false;
   } catch (e) {
    return false;
   }
  } else {
   return false;
  }
 }
 return Type
}

日期格式化

/**
 * 日期格式化
 * @param {*} date 日期對象
 * @param {*} beforeHyphen 年月日連字符
 * @param {*} afterHyphen 時分秒連字符
 */
function formatDate(date = new Date(), beforeHyphen = '-', afterHyphen = ':') {
 const formatNumber = n => {
  n = n.toString()
  return n[1] ? n : `0${n}`
 }
 const year = date.getFullYear()
 const month = date.getMonth() + 1
 const day = date.getDate()
 const hour = date.getHours()
 const minute = date.getMinutes()
 const second = date.getSeconds()
 const ymd = [year, month, day].map(formatNumber).join(beforeHyphen)
 const hms = [hour, minute, second].map(formatNumber).join(afterHyphen)
 return `${ymd} ${hms}`
}

把時間戳轉(zhuǎn)換為剩余的天、時、分、秒

/**
 * 把時間戳轉(zhuǎn)換為剩余的天、時、分、秒,一般應(yīng)用于倒計時場景中
 * @param {*} timestamp 時間戳
 */
function converTimestamp(timestamp) {
 const formatNumber = n => {
  n = n.toString()
  return n[1] ? n : `0${n}`
 }
 let day = Math.floor((timestamp / 1000 / 3600) / 24);
 let hour = Math.floor((timestamp / 1000 / 3600) % 24);
 let minute = Math.floor((timestamp / 1000 / 60) % 60);
 let second = Math.floor(timestamp / 1000 % 60);
 return {
  day: day,
  hour: formatNumber(hour),
  minute: formatNumber(minute),
  second: formatNumber(second)
 }
}

從數(shù)組中隨機取出一項

// 從數(shù)組中隨機取出一項
function getRandomItemByArray(items) {
 return items[Math.floor(Math.random() * items.length)];
}

將有父子關(guān)系的數(shù)組轉(zhuǎn)換成樹形結(jié)構(gòu)數(shù)據(jù)

let data = [
 { parentId: 0, id: 1, value: 'xxx' },
 { parentId: 1, id: 3, value: 'xxx' },
 { parentId: 4, id: 6, value: 'xxx' },
 { parentId: 3, id: 5, value: 'xxx' },
 { parentId: 2, id: 4, value: 'xxx' },
 { parentId: 1, id: 2, value: 'xxx' },
]

// 轉(zhuǎn)換為樹形Array結(jié)構(gòu)
function toTreeAry(arr, pId = 0) {
 return arr
  .filter(({ parentId }) => parentId === pId)
  .map(a => ({
   ...a,
   children: toTreeAry(arr.filter(({ parentId }) => parentId !== pId), a.id)
  }))
}

// 轉(zhuǎn)換為樹形Object結(jié)構(gòu)
function toTreeObj(arr, pId = 0) {
 let res = {}
 arr.filter(({ parentId }) => parentId === pId)
  .forEach(a => {
   res[a.id] = {
    ...a,
    children: toTreeObj(arr.filter(({ parentId }) => parentId !== pId), a.id)
   }
  })
 return res
}

console.log(toTreeAry(data))
console.log(toTreeObj(data))

生成隨機字符串

// 隨機字符串
const randomStr = () => {
 return new Date().getTime() + '-' + Math.random().toString(36).substr(2)
}

過濾html標簽

// 過濾html標簽
const filterHTMLTag = (str) => {
 str = str.replace(/<\/?[^>]*>/g, ''); //去除HTML Tag
 str = str.replace(/[|]*\n/, '') //去除行尾空格
 str = str.replace(/&npsp;/ig, ''); //去掉npsp
 return str;
}

以上就是JavaScript常用工具函數(shù)庫匯總的詳細內(nèi)容,更多關(guān)于JavaScript工具函數(shù)庫的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • JS求解兩數(shù)之和算法詳解

    JS求解兩數(shù)之和算法詳解

    這篇文章主要介紹了JS求解兩數(shù)之和算法,結(jié)合實例形式詳細分析了JS求解兩數(shù)之和算法相關(guān)原理、實現(xiàn)方法與操作注意事項,需要的朋友可以參考下
    2020-04-04
  • 基于JavaScript實現(xiàn)復(fù)選框的全選和取消全選

    基于JavaScript實現(xiàn)復(fù)選框的全選和取消全選

    這篇文章主要為大家詳細介紹了基于JavaScript實現(xiàn)復(fù)選框的全選和取消全選,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • 基于JavaScript編寫一個翻卡游戲

    基于JavaScript編寫一個翻卡游戲

    這篇文章主要為大家詳細介紹了如何溧陽JavaScript編寫一個簡單的翻卡游戲,文中的示例代碼講解詳細,具有一定的借鑒價值,需要的可以參考一下
    2023-02-02
  • 詳解ES6 中的Object.assign()的用法實例代碼

    詳解ES6 中的Object.assign()的用法實例代碼

    這篇文章主要介紹了ES6 Object.assign()的用法及用途,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • JavaScript輸入郵箱自動提示實例代碼

    JavaScript輸入郵箱自動提示實例代碼

    這篇文章主要介紹了JavaScript輸入郵箱自動提示實例代碼,有需要的朋友可以參考一下
    2014-01-01
  • js鼠標滑輪滾動事件綁定的簡單實例(兼容主流瀏覽器)

    js鼠標滑輪滾動事件綁定的簡單實例(兼容主流瀏覽器)

    本篇文章主要介紹了js鼠標滑輪滾動事件綁定的簡單實例(兼容主流瀏覽器)。需要的朋友可以過來參考下,希望對大家有所幫助
    2014-01-01
  • requirejs按需加載angularjs文件實例

    requirejs按需加載angularjs文件實例

    本篇文章主要介紹了requirejs按需加載angularjs文件實例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • JS實現(xiàn)自動切換文字的導(dǎo)航效果代碼

    JS實現(xiàn)自動切換文字的導(dǎo)航效果代碼

    這篇文章主要介紹了JS實現(xiàn)自動切換文字的導(dǎo)航效果代碼,涉及javascript動態(tài)切換頁面樣式的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-08-08
  • Javascript的閉包

    Javascript的閉包

    所謂“閉包”,指的是一個擁有許多變量和綁定了這些變量的環(huán)境的表達式(通常是一個函數(shù)),因而這些變量也是該表達式的一部分。
    2009-12-12
  • javascript對中文按照拼音排序代碼

    javascript對中文按照拼音排序代碼

    將中文編入數(shù)組,調(diào)用數(shù)組的sort方法,再用到一個localeCompare即可實現(xiàn)中文排序,需要的朋友可以參考下
    2014-08-08

最新評論