js雖然提供了各種取得時間Date物件的不同屬性方法,如:getDate 方法 | getDay 方法 | getFullYear 方法 | getHours 方法 ... ... 等等,但是卻沒有像java那樣提供一個方法來供用戶來根據自身提供的模板(pattern),來格式化指定時間對象,所以自己就封裝了一個小方法,只供大家閒來調侃-.-,有好的建議還望慷慨指薦哦。
用到知識點:arguments:此物件代表正在執行的函數和呼叫它的函數的參數。不可明確創建,雖然有length屬性,且能像數組一樣以“[]”語法方式取值,但它並不是一個數組。 typeof object :運算符,傳回一個用來表示表達式的資料類型的字串。六種可能: "number," "string," "boolean," "object," "function," 和 "undefined."。 object.constructor:表示建立物件的函數。
object必須是物件或函數的名稱。基礎資料沒有該屬性。 exec 方法:以正規表示式模式在字串中執行查找,並傳回包含該查找結果的一個陣列。沒有找到匹配,則它返回 null。數組中同類型匹配元素不會重複出現。 str.split(Rex|str):以一個正規物件或子字串,將一個字串分割為子字串,然後將結果作為字串陣列傳回。 throw Error('msg'):拋出一個帶有Message訊息的Error。 throw 後面可跟任何表達式。 還有一些for..in用法,三目運算符,substr這些就不講了,比較簡單。
程式碼片段:
/**
* ***js時間日期格式化***
*
* 模版字串採嚴謹格式,超出則會拋出異常,且每類格式只可出現一次,如:yyyy-mm-yyyy 格式會拋出異常
*
* y-年 length: 2/4位元
* q-季度 length: 1位元
* M-月 length: 1~2位
* d-日 length: 1~2位
* H-時 length: 1~2位24小時制,h:12小時制
* m-分 length: 1~2位元
* s-秒 length: 1~2位
* S-毫秒 length: 固定1位
* @param {Date類型物件} date
* @param {String類型範本字串} fmt
* @return 格式化後時間日期字串
* @author lyt
*/
function DateFormat(date, fmt){
if (arguments.length != 2) // 參數個數校驗
throw Error('arguments長度不合法');
if (!date || (typeof date != 'object') || (d.constructor != Date)) // 參數合法性校驗
throw Error(arguments[0] ':型別不為Date型別');
if (/H /.test(fmt) && /h /.test(fmt))
throw Error("小時格式錯誤,同類型只能連續出現一次!");
/* 範本參數校驗,正規驗證方法 */
var verify = function(Rex ){
var arr = new RegExp(Rex).exec(fmt); // 獲得符合結果陣列
if (!arr) // 配對失敗回傳
return "";
if (fmt.split(Rex).length > 2) // 相同類型間隔出現多次
throw Error("fmt格式錯誤:同型別只能連續出現一次!");
return arr[0];
};
/**
* 提供月、天、時、分、秒通用配對替換
* @param {物件o屬性key} r
* @param {r對應正規物件} rex
**/
var common = function(r, rex) {
if(len !=1 && len !=2)
throw Error("月份格式錯誤:M只能出現1/2次");
len == 2 ? fmt=fmt.replace(rex, o[r].length==1 ? "0" o[r] : o[r]) : fmt=fmt.replace(rex, o[r]) ;
}
var o = { // 資料儲存物件
"y ": date.getFullYear() "", // 年
"q ": Math.floor((date.getMonth() 3) / 3), // 季度
"M ": date.getMonth() 1 "", // 月
"d ": date.getDate() "", // 日
"H ": date.getHours() "", // 24時
"h ": date.getHours() "", // 12時
"m ": date.getMinutes() "", // 分
"s ": date.getSeconds() "", // 秒
"S ": date.getMilliseconds() // 毫秒
}
for(var r in o) {
var rex, len, temp;
rex = new RegExp(r);
temp = verify(rex); // 符合所得字串
len = temp.length; // 長度
if(!len || len == 0)
continue;
if(r == "y ") {
if(len !=2 && len != 4)
throw Error("年份格式錯誤:y且只能出現2/4次");
len == 2 ? fmt=fmt.replace(rex, o[r].substr(2,3)) : fmt=fmt.replace(rex, o[r]);
} else if(r == "q ") {
if(len != 1)
throw Error("季度格式錯誤:q只能出現1次");
fmt=fmt.replace(rex, o[r]);
} else if(r == "h ") {
if(len !=1 && len !=2)
throw Error("小時格式錯誤:h且只能出現1/2次");
var h = (o[r] > 12 ? o[r]-12 : o[r]) "";
len == 2 ? fmt=fmt.replace(rex, h.length==1 ? "0" h : h) : fmt=fmt.replace(rex, h);
} else if(r == "S ") {
if(len != 1)
throw Error("毫秒數格式錯誤:S只能出現1次");
fmt=fmt.replace(rex, o[r]);
}else { // (r=="M " || r=="d " || r=="H " || r=="m " || r=="s ")
common(r, rex)
}
}
return fmt;
}
上幾個示範效果,供大家參考:
其他效果就不一一列舉了,感興趣的可以把程式碼拷貝下來直接測試就行了,有任何BUG或者有待優化的地方請慷慨指正哦。
以上便是這款非常好用的封裝函數的介紹了,是不是很實用呢,小伙伴們可以直接使用到自己的項目中。

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

記事本++7.3.1
好用且免費的程式碼編輯器

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境