ホームページ > 記事 > ウェブフロントエンド > JavaScriptの時間書式設定_javascriptスキルを詳しく解説
JS形式の日付と時刻のJSコードを書いてくれた先輩のおかげで、とても良くて強力です! ! !
はしがき:
js は、getDate メソッド | getFullyear メソッド | getHours メソッドなど、時刻 Date オブジェクトを取得するためのさまざまなメソッドを提供します。指定された時刻オブジェクトを自分で提供したテンプレート (パターン) に従ってフォーマットするため、誰もが笑うための小さなメソッドをカプセル化しました -.- 良い提案がある場合は、惜しみなく推奨してください。
使用した知識ポイント:
• argument: このオブジェクトは、実行される関数とそれを呼び出す関数のパラメーターを表します。これは明示的に作成することはできませんが、長さ属性があり、配列と同様に「[]」構文を使用して取得できますが、配列ではありません。
•typeof object: 演算子は、式のデータ型を表すために使用される文字列を返します。 6 つの可能性: 「数値」、「文字列」、「ブール値」、「オブジェクト」、「関数」、および「未定義」。
• object.constructor: オブジェクトを作成する関数を表します。 object はオブジェクトまたは関数の名前である必要があります。基になるデータにはこの属性がありません。
• exec メソッド: 正規表現パターンを使用して文字列の検索を実行し、検索結果を含む配列を返します。一致するものが見つからない場合は、null を返します。同じ型の一致する要素が配列内に繰り返し現れることはありません。
• str.split(Rex|str): 通常のオブジェクトまたは部分文字列を使用して文字列を部分文字列に分割し、結果を文字列配列として返します。
• throw Error('msg'): メッセージ情報を含むエラーをスローします。 throw の後には任意の式を続けることができます。
• for..in、三項演算子、substr の使用法もいくつかありますが、それらは比較的単純なので説明しません。
コードスニペット:
/** * ***js时间日期格式化*** <br> * <p> * 模版字符串采用严谨格式,超出则会抛出异常,且每类格式只可出现一次,如:yyyy-mm-yyyy 格式会抛异常 * </p> * y-年 length: 2/4位 <br> * q-季度 length: 1位 <br> * M-月 length: 1~2位 <br> * d-日 length: 1~2位 <br> * H-时 length: 1~2位24小时制,h:12小时制 <br> * m-分 length: 1~2位 <br> * s-秒 length: 1~2位 <br> * S-毫秒 length: 固定1位 * @param {Date类型对象} date * @param {String类型模板字符串} fmt * @return 格式化后时间日期字符串 * @author lyt * blongs: http://www.cnblogs.com/liuyitian/ */ 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; }
参考までに、デモンストレーション効果をいくつか示します:
console.log(DateFormat(new Date(),'Yyyy 年 q 四半期 M 月 dd 日 HH 時 m 分 s 秒 S ミリ秒'));
console.log(DateFormat(new Date(),'yyyy年yyq四半期M月dd日HH時m分s秒Sミリ秒'));
console.log(DateFormat(new Date(),'yyyy 年 q 四半期 M 月 dd 日 Hh 時 m 分 s 秒 S ミリ秒'));
console.log(DateFormat("私は時間オブジェクトではありません",'Yyyy 年 Q 四半期 M 月 dd 日 Hh 時 m 分 s 秒 S ミリ秒'));
console.log(DateFormat(new Date(),'yyyy 年 q 四半期 MMM 月 dd 日 HH 時 m 分 s 秒 S ミリ秒'));
他のエフェクトを 1 つずつリストすることはしません。興味がある場合は、コードをコピーして直接テストして、バグや最適化が必要な領域がある場合は、自由に修正してください。
上記の内容を通じて、JavaScript の時間フォーマットに関する知識を詳しく説明しました。気に入っていただければ幸いです。