摘要:前端對(duì)于數(shù)據(jù)的處理一般會(huì)用到等方法,下面逐次進(jìn)行分析方法用于調(diào)用數(shù)組的每個(gè)元素,并將元素傳遞給回調(diào)函數(shù)。注意對(duì)于空數(shù)組是不會(huì)執(zhí)行回調(diào)函數(shù)的。方法按照原始數(shù)組元素順序依次處理元素。
前端對(duì)于數(shù)據(jù)的處理一般會(huì)用到foreach、map、reduce、Object.values()、Object.keys()、Object.entries()等方法,下面逐次進(jìn)行分析
foreach
forEach() 方法用于調(diào)用數(shù)組的每個(gè)元素,并將元素傳遞給回調(diào)函數(shù)。foreach方法不會(huì)返回執(zhí)行結(jié)果。
注意: forEach() 對(duì)于空數(shù)組是不會(huì)執(zhí)行回調(diào)函數(shù)的。foreach會(huì)改變?cè)瓟?shù)組。
語(yǔ)法: array.forEach(function(currentValue, index, arr), thisValue)
示例: let schedulesObj = {}; dateArr.forEach((key) => { if (!schedulesObj[key]) { schedulesObj[key] = []; } schedulesObj[key].push(item); });
map
map() 方法返回一個(gè)新數(shù)組,數(shù)組中的元素為原始數(shù)組元素調(diào)用函數(shù)處理后的值。
map() 方法按照原始數(shù)組元素順序依次處理元素。
注意: map() 不會(huì)對(duì)空數(shù)組進(jìn)行檢測(cè)。
注意: map() 不會(huì)改變?cè)紨?shù)組。
語(yǔ)法: array.map(function(currentValue,index,arr), thisValue)
示例: const initItems = initEvaluateItems.map(item => { const { score, id, itemName, levelDesc, maxLevel } = item; return { score, id, itemName, levelDesc, maxLevel }; });
reduce
reduce() 方法接收一個(gè)函數(shù)作為累加器,數(shù)組中的每個(gè)值(從左到右)開始縮減,最終計(jì)算為一個(gè)值。
reduce() 可以作為一個(gè)高階函數(shù),用于函數(shù)的 compose。
注意: reduce() 對(duì)于空數(shù)組是不會(huì)執(zhí)行回調(diào)函數(shù)的。
語(yǔ)法: array.reduce(function(total, currentValue, currentIndex, arr), initialValue)
示例: let scheduleIdArray = Object.keys(curScheduleMonth).map(v => curScheduleMonth[v]).reduce((total, item) => { total = [...total, ...item]; return total; }, []);
Object.keys()
Object.keys() 方法會(huì)返回一個(gè)由一個(gè)給定對(duì)象的自身可枚舉屬性組成的數(shù)組,數(shù)組中屬性名的排列順序和使用 for...in 循環(huán)遍歷該對(duì)象時(shí)返回的順序一致 。
語(yǔ)法: Object.keys(obj)
示例: var anObj = { 100: "a", 2: "b", 7: "c" }; console.log(Object.keys(anObj)); // console: ["2", "7", "100"]
Object.values()
Object.values()方法返回一個(gè)給定對(duì)象自身的所有可枚舉屬性值的數(shù)組,值的順序與使用for...in循環(huán)的順序相同 ( 區(qū)別在于 for-in 循環(huán)枚舉原型鏈中的屬性 )。
語(yǔ)法: Object.values(obj)
示例: var an_obj = { 100: "a", 2: "b", 7: "c" }; console.log(Object.values(an_obj)); // ["b", "c", "a"]
Object.entries()
Object.entries()方法返回一個(gè)給定對(duì)象自身可枚舉屬性的鍵值對(duì)數(shù)組,其排列與使用 for...in 循環(huán)遍歷該對(duì)象時(shí)返回的順序一致(區(qū)別在于 for-in 循環(huán)也枚舉原型鏈中的屬性)。
語(yǔ)法: Object.entries(obj)
示例: const anObj = { 100: "a", 2: "b", 7: "c" }; console.log(Object.entries(anObj)); // [ ["2", "b"], ["7", "c"], ["100", "a"] ]
1.時(shí)間相關(guān)
{ "success":true, "code": "success", "message": "成功", "data": { "monthData":[ { "month":"2018-05", "displayDesc":"有服務(wù)", "showType":"1", "tips":"請(qǐng)您選擇" } ] "calendarData":[ { "date":["2018-06-02","2018-07-09"], "displayDesc":"有服務(wù)", "showType":"1", "tips":"請(qǐng)您評(píng)價(jià)" } ], "schedules":[ { "scheduleId":"1", "appCode":"106", "appName":"公共服務(wù)", "cityId":"321568", "categoryCode":"16", "scheduleType":"1", "userDesc":"社區(qū)醫(yī)療", "systemDesc":"", "remind":"1", "repeat":"1", "status":"2", "serviceUrl":"", "beginTime":"2018-04-25", "endTime":"2018-04-26", } ] } }
import moment from "moment/moment"; /** * 通過(guò)beginTime和endTime,將列表值按照天的維度進(jìn)行整理,產(chǎn)出的數(shù)據(jù)結(jié)構(gòu)scheduleByDay * @param schedules */ export function genSchedulesObj(schedules = []) { let schedulesObj = {}; schedules.forEach((item) => { let { beginTime, endTime } = item; let _beginTime = new Date(beginTime).getTime(); let _endTime = new Date(endTime).getTime(); let dateArr = []; let dateReduce = ((_endTime - _beginTime) / (1000 * 24 * 60 * 60) + 1) || 1; dateReduce > 0 ? {} : (dateReduce = 0); for (let i = 0; i < dateReduce; i++) { dateArr.push(moment(_beginTime).format("YYYY-MM-DD")); _beginTime += (1000 * 24 * 3600); } dateArr.forEach((key) => { if (!schedulesObj[key]) { schedulesObj[key] = []; } schedulesObj[key].push(item); }); }); // let flag = true; // for (let key in schedulesObj) { // for (let i = 0, len = schedulesObj[key].length; i < len; i++) { // if (schedulesObj[key][i].status < 3) { // flag = false; // break; // } // } // } return { schedulesObj }; } /** * calendarData 日期上顯示代辦內(nèi)容,根據(jù)這個(gè)數(shù)據(jù)創(chuàng)建tagData是一個(gè)一維數(shù)組,產(chǎn)出的數(shù)據(jù)結(jié)構(gòu)tagDataByMonth * @param calendarData */ export function genCalendarDataObj(calendarData = []) { let calendarDataObj = {}; calendarData.forEach((item) => { item.date.forEach((key) => { if (!calendarDataObj[key]) { calendarDataObj[key] = []; } calendarDataObj[key].push({ displayDesc: item.displayDesc, showType: item.showType }); }); }); return calendarDataObj; } /** * 獲取當(dāng)前月、上一個(gè)月、下一月及當(dāng)前月的開始、結(jié)束日期 */ export function getFormatMonth(currentDate) { const beginDate = moment(currentDate).startOf("month").add(-1, "M").format("YYYY-MM-DD"); const endDate = moment(currentDate).endOf("month").add(1, "M").format("YYYY-MM-DD"); const preMont = moment(currentDate).subtract(1, "months").format("YYYY-MM"); const nextMont = moment(currentDate).add(1, "months").format("YYYY-MM"); const currMont = moment(currentDate).format("YYYY-MM"); const month = preMont + "," + currMont + "," + nextMont; return { beginDate, endDate, preMont, nextMont, currMont, month }; }
2.工具類函數(shù)
/** * 正則表達(dá)式獲取地址欄參數(shù) */ export const getURLParameters = (url) => { url = url.split("?")[1] || ""; url = url.split("&"); return url.reduce((total, item) => { let itemArr = item.split("="); total[itemArr[0]] = itemArr[1]; return total; }, {}); }; /** * filter過(guò)濾 */ const filterArr = (scheduleByDay[currentDate] || []).filter(v => { return v.status !== 4; }); const tagData = Object.keys(tagDataByMonth).map((key) => { const obj = tagDataByMonth[key][0]; const scheduleByDayItem = scheduleByDay[key] || []; return { date: key, tag: scheduleByDayItem.length === 1 ? scheduleByDayItem[0].userDesc : obj.displayDesc, tagColor: obj.showType === "1" ? "#F5A623" : "#CCCCCC" }; }); let scheduleIdArray = Object.keys(curScheduleMonth).map(v => curScheduleMonth[v]).reduce((total, item) => { total = [...total, ...item]; return total; }, []); let scheduleId = scheduleIdArray.length ? scheduleIdArray[0].scheduleId : null; let isOnlyOne = scheduleId ? scheduleIdArray.every(v => v.scheduleId === scheduleId) : false; /** * 獲取服務(wù)端時(shí)間 */ getServerTimeAsync() { return new Promise((resolve) => { try { my.call("getServerTime", (res) => { resolve(res.time); }); } catch (e) { resolve(new Date().getTime()); } }); }, /** * 檢查文本域的長(zhǎng)度 * @param keyword * @returns {*} */ checkKeywordLength(keyword) { const { maxlength } = this.data; if (keyword.length > maxlength) { keyword = keyword.substring(0, maxlength); } return keyword; }, const { data: { items: initEvaluateItems } } = serviceKey; const initItems = initEvaluateItems.map(item => { const { score, id, itemName, levelDesc, maxLevel } = item; return { score, id, itemName, levelDesc, maxLevel }; });
3.層級(jí)較深的數(shù)據(jù)結(jié)構(gòu)
{ "success": true, "value": { "merchant": { "id": 0, #物理id "partakerId": 0, "partakerName": "string", "merchantPid": "string", "merchantName": "string", "owners": { "guarantee_owner":[{"account":"string","name":"string"}], }, #負(fù)責(zé)人 }, "extension":{ keyValues: { channel:{ key:{ id:"21", creator:"流年", dataSource:"", key:"duration", label:"項(xiàng)目周期", type:"date", isRequire:"Y" }, value:"2018-06-02 17:55:12" }, is_sign:{ key:{ id:"32", creator:"lily", dataSource:"[{"key":"current","value":"今天"},{"key":"last","value":"昨天"}]", key:"startTime", label:"啟動(dòng)時(shí)間", type:"select", isRequire:"N" }, value:"last" }, merchantInfo:{ key:{ id:"02", creator:"jack", dataSource:"", key:"taskCount", label:"任務(wù)量", type:"number", isRequire:"Y" }, value:"55" }, code:"DEFAULT", tempName:"社區(qū)服務(wù)" } }, #動(dòng)態(tài)字段 }, "msg": "string", #錯(cuò)誤信息 "code": "string" #錯(cuò)誤碼 } const { stat, value = {}, msg } = response || {}; if (stat === "fail") { message.error(msg); } const { merchant = {}, extension = {} } = value; const { keyValues = {} } = extension; const extenData = Object.entries(keyValues).map(v => { const [arr1, arr2] = v; const { key, recordId, value: newValue } = arr2; return { key, value: newValue, recordId }; }); console.log("動(dòng)態(tài)數(shù)據(jù)-----", extenData); const linksObj = { 活動(dòng)信息: links.slice(0, 2), 活動(dòng)商戶信息: links.slice(2, 8), 保障商戶信息: links.slice(8), }; getFormDataDom = (data) => { const { getFieldDecorator } = this.props.form; const { formItem = {} } = this.props; return data.map((val) => { const { name, id, isSelect = false, isSelectInputOwners = false, isInput = false } = val; let isSimpleInitial; let isSelectInputOwnersInitial; if (isSelect || isInput) { isSimpleInitial = formItem && formItem[id] ? formItem[id] : ""; } if (isSelectInputOwners) { isSelectInputOwnersInitial = formItem && formItem[id] && formItem[id].length > 0 ? formItem[id].map(v => v.name) : []; } const initialValue = isSelectInputOwners ? isSelectInputOwnersInitial : isSelect || isInput ? isSimpleInitial : ""; return ({getFieldDecorator(`${id}`, { initialValue })(this.getFormItem(formItem, val)) } ); }); }; extenArr = (extenData = []) => { return extenData.map((item) => { const { key, value } = item; const { fieldKey, fieldLabel } = key; let { dataSource } = key; let spanValue = ""; if (dataSource === "") { spanValue = value; } else { try { dataSource = dataSource.replace(/"/img, """); const jsonValue = JSON.parse(dataSource); spanValue = jsonValue.reduce((total, i) => { total[i.key] = i.value; return total; }, {})[value]; } catch (e) { spanValue = ""; } } return { name: fieldLabel, id: fieldKey, spanValue }; }); };
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/97503.html
摘要:實(shí)際中更多是作為其他數(shù)據(jù)結(jié)構(gòu)的子結(jié)構(gòu),如哈希桶圖的鄰接表等等。實(shí)際中使用的鏈表數(shù)據(jù)結(jié)構(gòu),都是帶頭雙向循環(huán)鏈表。 文章目錄 一.算法的時(shí)間復(fù)雜度和空間復(fù)雜度1.算法...
摘要:什么是復(fù)雜度分析數(shù)據(jù)結(jié)構(gòu)和算法解決是如何讓計(jì)算機(jī)更快時(shí)間更省空間的解決問(wèn)題。分別用時(shí)間復(fù)雜度和空間復(fù)雜度兩個(gè)概念來(lái)描述性能問(wèn)題,二者統(tǒng)稱為復(fù)雜度。復(fù)雜度描述的是算法執(zhí)行時(shí)間或占用空間與數(shù)據(jù)規(guī)模的增長(zhǎng)關(guān)系。這就是大時(shí)間復(fù)雜度表示法。 showImg(https://segmentfault.com/img/bVbtpFP?w=1000&h=574); 復(fù)雜度分析是整個(gè)算法學(xué)習(xí)的精髓,只要...
摘要:同樣以里的模塊為例,替換前后的卷積分支復(fù)雜度如下中使用與卷積級(jí)聯(lián)替代卷積中提出了卷積的,在確保感受野不變的前提下進(jìn)一步簡(jiǎn)化。 在梳理CNN經(jīng)典模型的過(guò)程中,我理解到其實(shí)經(jīng)典模型演進(jìn)中的很多創(chuàng)新點(diǎn)都與改善模型計(jì)算復(fù)雜度緊密相關(guān),因此今天就讓我們對(duì)卷積神經(jīng)網(wǎng)絡(luò)的復(fù)雜度分析簡(jiǎn)單總結(jié)一下下。1.時(shí)間復(fù)雜度1.2 卷積神經(jīng)網(wǎng)絡(luò)整體的時(shí)間復(fù)雜度示例:用 Numpy 手動(dòng)簡(jiǎn)單實(shí)現(xiàn)二維卷積假設(shè) Stride...
閱讀 2938·2023-04-25 19:08
閱讀 1427·2021-11-16 11:45
閱讀 1988·2021-10-13 09:40
閱讀 4153·2021-09-30 09:47
閱讀 2425·2019-08-30 15:44
閱讀 2297·2019-08-30 13:03
閱讀 1399·2019-08-30 12:56
閱讀 1899·2019-08-26 14:04