摘要:混合使用計算時分秒本文出自從零到壹全棧部落作者黎躍春追時間的人簡介是推出的一個天挑戰(zhàn)。完整中文版指南及視頻教程在從零到壹全棧部落。效果圖第天挑戰(zhàn)的內(nèi)容主要是如何將一系列的加起來,最終計算總時間,總時間用時分秒顯示。
Day18 - Reduce、Map混合使用計算時分秒
效果圖本文出自:從零到壹全棧部落
作者:?黎躍春-追時間的人
簡介:JavaScript30 是 Wes Bos 推出的一個 30 天挑戰(zhàn)。項目免費提供了 30 個視頻教程、30 個挑戰(zhàn)的起始文檔和 30 個挑戰(zhàn)解決方案源代碼。目的是幫助人們用純 JavaScript 來寫東西,不借助框架和庫,也不使用編譯器和引用。現(xiàn)在你看到的是這系列指南的第 18 篇。完整中文版指南及視頻教程在 從零到壹全棧部落。
第18天挑戰(zhàn)的內(nèi)容主要是如何將一系列的data-time加起來,最終計算總時間,總時間用時分秒顯示。
HTML、CSS代碼Adding Up Times with Reduce
//獲取整個 li NodeList let items = document.querySelectorAll("ul li"); //創(chuàng)建一個空數(shù)組,存儲所有data-time字符串 let itemtimearray = []; //通過for循環(huán)將每個li中的data.time添加到 itemtimearray 數(shù)組中 for (let item of items) { itemtimearray.push(item.dataset.time); } //遍歷itemtimearray數(shù)組,返回一個新的數(shù)組 let spiltitmes = itemtimearray.map(item => { //通過 : 將字符串拆分成數(shù)組 let temp = item.split(":"); //返回對象包涵分和秒的對象 return { min: temp[0], sencond: temp[1] } }); //初始化分和秒 let totalMin = 0; let totalSec = 0; //通過reduce函數(shù)將spiltitmes數(shù)組中所有的min疊加并存儲到totalMin中 totalMin = spiltitmes.reduce((total, time) => { return total += parseInt(time.min); }, 0); //通過reduce函數(shù)將spiltitmes數(shù)組中所有的sencond疊加并存儲到totalSec中 totalSec = spiltitmes.reduce((total, time) => { return total += parseInt(time.sencond); }, 0); //求余計算秒 let finalSecond = parseInt(totalSec % 60); //計算一共多少分鐘 let finalMin = parseInt(totalMin + (totalSec / 60)) % 60; //計算一共多少小時 let finalHour = parseInt((totalMin + (totalSec / 60)) / 60); //輸出時分秒 console.log(`共${finalHour}小時,${finalMin}分鐘,${finalSecond}秒。`);方法二
// 1. [...items] => 將其展開為數(shù)組 // 2. Array.from(items) => 使用Array.from()將items轉(zhuǎn)換為數(shù)組 // 獲取所有節(jié)點 // 3. const timeNodes = Array.from(document.querySelectorAll("[data-time]")); // 4. parseFloat: // [].map(parseFloat) => [].map(function(x) {retunr parseFloat(x)}); // 獲取所有的帶有data-time屬性的節(jié)點 const timeNodes = Array.from(document.querySelectorAll("[data-time]")); const seconds = timeNodes //返回一個包涵所有data-time值的數(shù)組 .map(node => node.dataset.time) //返回一個將data-time解析成秒的數(shù)組 .map(timeCode => { //timeCode為 1:43 這樣格式的字符串 //timeCode.split(":") 返回一個新數(shù)組,數(shù)組里面裝的是分和秒的時間 //[].map(parseFloat) => [].map(function(x) {retunr parseFloat(x)}); const [mins, secs] = timeCode.split(":").map(parseFloat); //將分乘以60+秒,計算所有的秒,并返回 return (mins * 60) + secs; }) //將數(shù)組中的所有的秒疊加并返回 .reduce((total, vidSeconds) => total + vidSeconds); //通過求余取整計算時分秒 let secondsLeft = seconds; const hours = Math.floor(secondsLeft / 3600); secondsLeft = secondsLeft % 3600; const mins = Math.floor(secondsLeft / 60); secondsLeft = secondsLeft % 60; //打印輸出 console.log(hours, mins, secondsLeft);
完結(jié):所有代碼解釋在代碼注釋中。
源碼下載Github Source Code
全棧部落 | 區(qū)塊鏈部落 |
---|---|
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/84761.html
摘要:但有一個限制它們不能修改定義的方法的局部變量的內(nèi)容。如前所述,這種限制存在的原因在于局部變量保存在棧上,并且隱式表示它們僅限于其所在線程。 2014年,Oracle發(fā)布了Java8新版本。對于Java來說,這顯然是一個具有里程碑意義的版本。尤其是那函數(shù)式編程的功能,避開了Java那煩瑣的語法所帶來的麻煩。 這可以算是一篇Java8的學(xué)習(xí)筆記。將Java8一些常見的一些特性作了一個概要的...
摘要:獲取當天是幾號獲取當天是星期幾獲取本月的第一天取本月最后一天是不是很贊提供時分秒不提供年月日,也是線程安全并且不可變類。樣例獲取當前的小時小時數(shù)加結(jié)果包含年月日時分秒,精確到納秒級別,同樣是線程安全并且不可變類。 java.util.Date 包含有年月日時分秒,精確到毫秒級別。官方解釋: // The class Date represents a specific instant ...
摘要:更新今天又發(fā)現(xiàn)了一種簡單的方法可以直接對年月日時分秒進行操作,假如今天那么所得昨天為昨天的時間前天的時間其中,函數(shù)為擴展函數(shù)。 1、時間格式化 1 //昨天的時間 2 var day1 = new Date(); 3 day1.setTime(day1.getTime()-24*60*60*1000); 4 var s1 = day1.getFullYear()+- + (da...
閱讀 2071·2023-04-25 22:58
閱讀 1419·2021-09-22 15:20
閱讀 2705·2019-08-30 15:56
閱讀 1996·2019-08-30 15:54
閱讀 2113·2019-08-29 12:31
閱讀 2736·2019-08-26 13:37
閱讀 601·2019-08-26 13:25
閱讀 2103·2019-08-26 11:58