freeCodeCamp/curriculum/challenges/chinese-traditional/03-front-end-development-li.../front-end-development-libra.../build-a-25-5-clock.md

6.0 KiB
Raw Blame History

id title challengeType forumTopicId dashedName
bd7158d8c442eddfaeb5bd0f 構建一個番茄時鐘 3 301373 build-a-25--5-clock

--description--

目標: 構建一個應用,功能和 https://25--5-clock.freecodecamp.rocks 類似。

完成以下需求,並且通過所有測試。 可以使用你需要的任何庫或 API。 賦予它你自己的個人風格。

可以使用 HTML、JavaScript、CSS、Bootstrap、SASS、React、Redux、jQuery 來完成這個挑戰。 但鑑於這個章節的學習內容與前端框架相關,推薦使用一款前端框架(比如 React來完成這個挑戰不推薦使用前面沒有提到的技術否則風險自負。 不推薦使用前面沒有提到的技術,否則風險自擔。 我們有計劃新增其他前端框架課程,例如 Angular 和 Vue不過目前還沒有這些內容。 我們會接受並嘗試修復你在使用推薦技術棧創建項目時報告的問題。 編碼愉快!

需求 1 應該能看到一個具有id="break-label"屬性的元素,這個元素的內容應該是一個字符串(例如:"Break Length")。

需求 2 應該能看到一個具有id="session-label"屬性的元素,這個元素的內容應該是一個字符串(例如:"Session Length")。

需求 3 應該能看到兩個可以點擊的元素,他們分別具有如下 idid="break-decrement"id="session-decrement"

需求 4 應該能看到兩個可以點擊的元素,它們分別具有如下 idid="break-increment"id="session-increment"

需求 5 應該能看到一個具有 id="break-length" 屬性的元素,這個元素默認展示數值應該爲 5加載後

需求 6 應該能看到一個具有 id="session-length" 屬性的元素,這個元素默認展示數值應該爲 25加載後

需求 7 應該能看到一個具有 id="timer-label" 屬性的元素,這個元素包含一個表示當前狀態的字符串(例如:"Session")。

需求 8 應該能看到一個具有 id="time-left" 屬性的元素。 注意:暫停或者運行時,該元素的內容應始終以 mm:ss 格式顯示(如 25:00

需求 9 應該能看到一個具有 id="start_stop" 屬性的可點擊的元素。

需求 10 應該能看到一個具有 id="reset" 屬性的可點擊的元素。

需求 11 當點擊 id 屬性爲 reset 的元素時,運行中的計時器都應該停止,id="break-length" 元素中的值應該重新回到 5id="session-length" 元素中的值應該重新回到 25id="time-left" 元素應該重置爲默認狀態。

需求 12 當點擊 id 屬性爲 break-decrement 的元素時,id="break-length" 元素的值應該減去 1且我應該能看到更新後的值。

需求 13 當點擊 id 屬性爲 break-increment 的元素時,id="break-length" 元素的值應該增加 1且應該能看到更新後的值。

需求 14 當點擊 id 屬性爲 session-decrement 的元素時,id="session-length" 元素的值應該減去 1且應該能看到更新後的值。

需求 15 當點擊 id 屬性爲 session-increment 的元素時,id="session-length" 元素的值應該增加 1且應該能看到更新後的值。

需求 16 工作或者休息長度不應該可以設置爲 <= 0 的值。

需求 17 工作或者休息長度比應該可以設置爲 > 60 的值。

需求 18 當首次點擊具有 id="start_stop" 屬性的元素時,計時器應該根據 id="session-length" 元素當前顯示的值開始運行,即使該值已從原始值 25 遞增過或遞減過。

需求 19 如果計時器正在運行id 屬性爲 time-left 的元素應該以 mm:ss 的格式展示剩餘的時間按1遞減並且每秒更新一次顯示的值

需求 20 如果計時器正在運行,當點擊 id="start_stop" 元素時,倒計時應該暫停。

需求 21 如果計時器已經暫停,當點擊 id="start_stop" 元素時,倒計時應該從暫停的時間點恢復運行。

需求 22 當一個工作倒計時結束(注意:計時器必須達到 00:00並且新的倒計時開始運行時id 屬性爲 timer-label 的元素應該顯示一個表示已經開始休息的字符串。

需求 23 當一個工作倒計時結束(注意:計時器必須達到 00:00應該開始一個新的休息倒計時時間應該從 id="break-length" 元素中當前顯示的值開始計算。

需求 24 當一個休息倒計時結束(注意:計時器必須達到 00:00並且新的倒計時開始運行時id 屬性爲 timer-label 的元素應該顯示一個表示已經開始工作的字符串。

需求 25 當一個休息倒計時結束(注意:計時器必須達到 00:00應該開始一個新的工作倒計時時間應該從 id="session-length" 元素中當前顯示的值開始計算。

需求 26 當一個倒計時結束(注意:計時器必須達到 00:00應該播放一個表示時間到了的聲音提示。 這個提示音應該使用 HTML5 的 audio標籤並有一個 id="beep" 屬性。

需求 27 具有id="beep"屬性的音頻元素時長應該至少有一秒。

需求 28 當點擊 id 屬性爲 reset 的元素時id 屬性爲 beep 的音頻元素必須停止播放並回到開頭。

你可以使用 CodePen 模版創建你的新項目,點擊 Save 即可創建你的新項目。 或者你可以在任何你喜歡的環境中使用以下 CDN 鏈接來運行測試:https://cdn.freecodecamp.org/testable-projects-fcc/v1/bundle.js

當你完成了本項目,並且該項目所有測試運行通過, 請提交項目的 URL。

--solutions--

// solution required