摘要:在開發項目的時候,有一些場景用到次數頻繁的函數,就封裝在了自己的工具類里,在這里和大家分享一下通過獲取到數據列表中對應顯示的字段經常做平臺類的項目,容易碰到這樣的場景,增刪改查頁面,添加完之后,表格要顯示某個類型,但是接口返回數據是類型,就
在開發項目的時候,有一些場景用到次數頻繁的函數,就封裝在了自己的工具類里,在這里和大家分享一下
1. 通過value獲取到數據列表中對應顯示的字段經常做平臺類的項目,容易碰到這樣的場景,增刪改查頁面,添加完之后,表格要顯示某個類型,但是接口返回數據是類型ID,就可以通過這個方法得到對應要顯示的字段了。
用法示例:let list = [{id: 1, name: "深圳"}, {id: 2, name: "廣州"}] getDataName({dataList: arr, value: "id", label: "name", data: 1}) // 深圳 getDataName({dataList: arr, value: "id", label: "name", data: 2}) // 廣州 /** * 通過value找到在列表中對應的名字 * @param {Object} obj * @param obj.dataList 數據列表 * @param obj.value 數據的值對應的字段名稱 例如 "value" * @param obj.label 數據的說明對應的字段名稱 例如 "label" * @param obj.data 當前傳入的數據值 * @return name 返回當前傳入值在數組中對應的名字 */ getDataName: (obj) => { let name = obj.data if (Array.isArray(obj.dataList) && obj.dataList.length > 0) { for (let i = 0; i < obj.dataList.length; i++) { if (obj.dataList[i][obj.value] == obj.data) { name = obj.dataList[i][obj.label] } } } return name }2. 對請求失敗的HTTP狀態碼做處理
說多了都是淚,之前公司接口返回數據,一開始沒有做異常處理,然后在使用的時候一旦出現什么問題頁面上就是一大堆的英文,很長很長一串,或者是出現問題了不返回錯誤原因,然后說影響用戶體驗,但是后端又不做異常處理,于是就寫了一個關于http狀態碼的處理。根據返回的狀態碼頁面上顯示對應的提示內容,不過感覺稍微正常的流程都用不上這個,哈哈
/** * 對請求失敗的HTTP狀態嗎做處理 * @param {Number} code HTTP狀態碼 * @param {String} message 錯誤提示 * @return message 返回處理過的提示信息 */ requestError: (code, message) => { let statusCode = (code + "").replace(/[^0-9]+/g, "") - 0 switch (statusCode) { case 400: return "Bad Request (錯誤的請求)" case 401: return "Unauthorized (請求要求身份驗證)" case 403: return "Forbidden (服務器拒絕請求)" case 404: return "NOT Found (服務器找不到請求的資源)" case 405: return "Bad Request (禁用請求中指定的方法)" case 406: return "Not Acceptable (無法使用請求的內容特性響應請求的網頁)" case 407: return "Proxy Authentication Required (需要代理授權)" case 408: return "Request Timed-Out (服務器等候請求時發生超時)" case 409: return "Conflict (服務器在完成請求時發生沖突。服務器必須在響應中包含有關沖突的信息)" case 410: return "Gone (請求的資源已被永久刪除)" case 411: return "Length Required (服務器不接受不含有效內容長度標頭字段的請求)" case 412: return "Precondition Failed (未滿足前提條件)" case 413: return "Request Entity Too Large (請求實體過大)" case 414: return "Request, URI Too Large (請求的 URI 過長)" case 415: return "Unsupported Media Type (不支持的媒體類型)" case 429: return "您的操作過于頻繁,請稍后重試" case 500: return "Internal Server Error (服務器內部錯誤)" case 501: return "Not Implemented (尚未實施)" case 502: return "Bad Gateway (錯誤網關)" case 503: return "Server Unavailable (服務不可用)" case 504: return "Gateway Timed-Out (網關超時)" case 505: return "HTTP Version not supported (HTTP 版本不受支持)" default: return message } },3. 傳入時間戳,轉換指定的時間格式
這個是本人用的非常多的一個函數,平時經常需要對時間處理,就只需要傳入時間戳或者時間格式的字符串,然后指定要轉換的時間格式,就可以了,很方便
用法示例:switchTime(new Date()) // 傳入當前時間,默認返回當時時間,格式為 YYYY-MM-DD hh:mm:ss switchTime("2018-11-10", "YYYY.MM.DD") // 2018.11.10 /** * 傳入時間戳(或者時間格式的數據),轉換指定的時間格式 * @param {Number} val 時間戳(或者時間格式的數據) * @param {String} dateType 要得到的時間格式 例如 YYYY-MM-DD hh:mm:ss * @return dataStr 例如 YYYY-MM-DD hh:mm:ss */ switchTime: (val = +new Date(), dateType = "YYYY-MM-DD hh:mm:ss") => { // 將字符串轉換成數字 let timeStamp, dateStr, str timeStamp = +new Date(val) // 如果轉換成數字出錯 if (!timeStamp) { return val } // 得到時間字符串 dateStr = new Date(timeStamp) str = dateType.replace("YYYY", dateStr.getFullYear()) str = str.replace("MM", (dateStr.getMonth() + 1 < 10 ? "0" : "") + (dateStr.getMonth() + 1)) str = str.replace("DD", (dateStr.getDate() < 10 ? "0" : "") + dateStr.getDate()) str = str.replace("hh", (dateStr.getHours() < 10 ? "0" : "") + dateStr.getHours()) str = str.replace("mm", (dateStr.getMinutes() < 10 ? "0" : "") + dateStr.getMinutes()) str = str.replace("ss", (dateStr.getSeconds() < 10 ? "0" : "") + dateStr.getSeconds()) return str }4. 瀏覽器打開新窗口
在平時開發中,一定會有這樣的需求,打開新窗口。但是用window.open的方式往往會碰到被瀏覽器攔截的問題,所以可以用a標簽通過超鏈接的方式打開新窗口。
往往在下載文件的時候也會用到這個方法。不過下載文件分為幾種情況,一種是直接訪問一個地址,瀏覽器會自動解析并且下載,還有一種情況就是后端返回的是一個文件,這個時候需要先在響應類型中加上blob處理之后,再去處理。這種情況下訪問解析后的地址,往往是打開一個新窗口并訪問,并不會自動下載,而需要下載的話需要給a標簽再加上一個download屬性。
用法示例:openWindow("https://www.baidu.com") // 默認打開方式為新窗口, id為open /** * a模擬window.open,不會被瀏覽器攔截 * @param {String} url a標簽打開的地址 * @param {String} id a標簽的ID * @param {String} targetType a標簽點擊打開的方式(當前頁面打開還是新窗口打開) */ openWindow: (url, targetType = "_blank", id = "open") => { // 如果存在則刪除 if (document.getElementById(id)) { document.body.removeChild(document.getElementById(id)) } let a = document.createElement("a") a.setAttribute("href", url) a.setAttribute("download", url) a.setAttribute("target", targetType) a.setAttribute("id", id) document.body.appendChild(a) a.click() },5. 將有層級關系的列表轉換成樹狀數據
不知道大家碰到樹狀結構的情況,但是本人開發的時候,因為開發的平臺類的項目較多,所以經常碰到樹狀的數據結構。
以前都是叫后端直接返回樹狀數據的,但是后端好像也不喜歡處理這樣的數據,就自己寫了一個方法。
傳入有層級關系的列表數據,然后根據定義的參數,處理成樹狀的數據結構。
用法示例:let arr = [{id: 1, pid: 0, name: "一級"}, {id: 2, pid: 1, name: "二級"}], arr1 = getTreeArr({key: "id", pKey: "pid", rootPValue: 0, data: arr}) 得到的數據為: arr1 = [ {id: 1, pid: 0, name: "一級", children: [{id: 2, pid: 1, name: "二級", children: []}] } ] /** * 將一級的數據結構處理成樹狀數據結構 * @param {Object} obj {key, pKey, data} * @param obj.key 字段名稱 比如id * @param obj.pKey 父字段名稱 比如 pid * @param obj.rootPValue 根節點的父字段的值 * @param obj.data 需要處理的數據 * @return {Array} arr */ getTreeArr: (obj) => { if (!Array.isArray(obj.data)) { console.log("getTreeArr=>請傳入數組") return [] } let arr = obj.data, arr1 = [] // 將數據處理成數狀結構 arr.forEach(item => { let index = 0 item.children = [] arr.forEach(item1 => { // 得到樹結構關系 if (item[obj.key] === item1[obj.pKey]) { item.children.push(item1) } // 判斷根節點 if (item1.id !== item.pid) { index++ } // 傳入根節點,根據傳入的根節點組成樹結構 if (rootPValue in obj && item[obj.pKey] === obj.rootPValue) { arr1.push(item) } }) // 沒傳入根節點,根據當前數據結構得到根節點 if (!(rootPValue in obj) && index === arr.length) { arr1.push(item) } }) return arr1 }6. 占位顯示
寫vue組件的時候,總是習慣用對象去做參數,因為覺得把參數變成對象的形式維護起來會非常方便,每次增加參數的時候只需要在對象中加上屬性,接受的地方對屬性做處理就好了。
但是vue組件的話,Object是不能設置默認值的,沒有默認值的話,讀取對象的屬性便是一個錯誤的語法,所以就寫了一個占位顯示的方法,比如
用法示例:showData(obj, "name", "名字") // 當obj未傳入的時候顯示 ‘名字’, 傳入后顯示為 obj.name /** * 用來判斷對象不存在是,顯示的字段數據 * @param {Object} obj 對象 * @param {String} key 要顯示的屬性 * @param {String} staticName 屬性不存在時顯示的值 */ showData (obj, key, staticName) { if (!obj) { obj = {} } if (obj && obj[key]) { return obj[key] } else { return staticName } }7. 數組(對象數組去重)
使用和參數說明
用法示例:handleRepeatArr({data: [1 , 1 ,1]}) // [1] handleRepeatArr({data: [{name: 1}, {name: 1}], key: "name"}) // [{name: 1}] /** - 數組去重 - @param {Array} data 要去重的數組 - @param {String} key 作為去重依據的字段 (處理對象數組時需要傳入) - @return arr 返回處理后的數據 */
1.遞歸去重(數據無法保持之前的排序)
handleRepeatArr ({data, key}) { if (!Array.isArray(data)) { console.log("請傳入數組") return } // 先對數據做排序處理 data = data.sort((item, item1) => { if (key) { return item[key] - item1[key] } return item - item1 }) // 遞歸去重 function getData (index) { if (index >= 1) { // 判斷當前數據和下一條數據是否相等 let result = key ? data[index][key] === data[index - 1][key] : data[index] === data[index - 1] if (result) { data.splice(index, 1) } getData(index - 1) } } getData(data.length - 1) return data }
2.根據對象的屬性不同去重 (推薦使用)
handleRepeatArr ({data, key}) { if (!Array.isArray(data)) { console.log("請傳入數組") return } let arr = [], obj = {} data.forEach((item, index) => { let attr = key ? item[key] : item if (!obj[attr]) { obj[attr] = index + 1 arr.push(item) } }) return arr }
3.利用indexOf以及forEach (適合處理數組,不適合處理對象數組)
handleRepeatArr ({data, key}) { if (!Array.isArray(data)) { console.log("請傳入數組") return } let arr = [] data.forEach((item, index) => { // 如果當前元素在之后沒有出現過(后面出現的數據會保留) // let result = data.indexOf(item, index + 1) // 如果當前元素在之前沒有出現過(前面出現的數據會保留) let result = index === 0 ? -1 : data.lastIndexOf(item, index - 1) if (result === -1) { arr.push(item) } }) return arr }
4.雙層循環去重 (占用內存高)
handleRepeatArr ({data, key}) { if (!Array.isArray(data)) { console.log("請傳入數組") return } for (let i = 0, len = data.length; i < len; i++) { for (let j = i + 1; j < len; j++) { let result = key ? data[i][key] === data[j][key] : data[i] === data[j] if (result) { data.splice(j, 1) len-- j-- } } } return data }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/100439.html
摘要:然鵝在過去的兩個月里,對的理解發生了一波三折的變化。發布自版本發布之后,一直致力于提升版本迭代速度,盡可能地通過小的更新來修復存在的問題。 推薦 1. 深入淺出 React 高階組件 https://zhuanlan.zhihu.com/p/... 由高階函數引申高階組件,高階組件是接受 React 組件作為輸入,輸出一個新的 React 組件的組件,本文介紹了在 React 工程中如...
摘要:在數組中循環使用將數組的第一個元素除去直到函數的返回值為。使用匿名內部函數范圍來聲明未定義的內存空間使用閉包來存儲返回值。返回頂部從數組中移除給定函數返回的元素使用查找返回值的數組元素和以使用刪除元素。使用執行從右向左的函數組合。 showImg(https://segmentfault.com/img/bV0PXR?w=400&h=80); Util.js (持續更新中...) ...
摘要:對于所訪問的每個元素,函數應該將該元素傳遞給所提供的回調函數。 HTML 在線閱讀Github地址 題目列表 HTML HTML和XHTML的區別 Html的語義化 Doctype的文檔類型 cookie、sessionSttorage、localStory區別 HTML全局屬性(global attribute)有哪些? 常見的瀏覽器內核有哪些? 介紹一下你對瀏覽器內核的理解?...
閱讀 1997·2019-08-30 15:54
閱讀 3546·2019-08-30 15:52
閱讀 1833·2019-08-29 17:20
閱讀 2527·2019-08-29 17:08
閱讀 2357·2019-08-26 13:24
閱讀 805·2019-08-26 11:59
閱讀 2790·2019-08-23 14:50
閱讀 627·2019-08-23 14:20