国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > WEB開發 > 正文

給javascript的Date添加parse和format函數

2024-04-27 15:14:22
字體:
來源:轉載
供稿:網友

前端開發中遇到日期字符串的解析和格式化問題,為了滿足更多情況,于是花心思自己寫了一個版本,適用較多情況,如下:

var date = new Date();date = date.parse("Tues,二月 07 2017 21:36:05.234", "[W:week],[M:月] DD YYYY hh:mm:ss.xxx");var str = date.format("YYYY-MM-DD");console.log(str); // 2017-02-07

/*  amuliang 2017/2/7 22:41 982632988@QQ.com    parse函數基于types解析,對應關系如下        Y 年        M 月        D 日        W 星期        h 時        m 分        s 秒        x 毫秒    每種類型可以有多個長度,且它們的分割方式任意,如YYYY-MM-DD, YY,MM,DD    并且支持詞語解析,格式為[type:label],如[M:month],且必須有明顯的分隔字符,    如"[M:month] YYYY",不能寫成"[M:month]YYYY",因為詞語長度不固定如Sunday與Tuesday長度就不相同    下面是用法示例:    var date = new Date();    date.parse("星期二,二月 07 2017 21:36:05.234", "[W:星期],[M:月] DD YYYY hh:mm:ss.xxx");*/;(function() {//*****************************************************var datestr, dateformat, index, char;var types = {    "Y": {        result: 0,    },    "M": {        Words: {            "月": ["一月", "二月", "三月", "四月", "五月", "六月", "七月", "八月", "九月", "十月", "十一月", "十二月"],            "month": ["Jan", "Feb", "Mar", "APR", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],            "fullmonth": ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"],        },        result: 0,    },    "D": {        result: 0,    },    "W": {        words: {            "星期": ["星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"],            "week": ["Sun", "Mon", "Tues", "Wed", "Thur", "Fri", "Sat"],            "fullweek": ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"],        },        result: 0,    },    "h": {        result: 0,    },    "m": {        result: 0,    },    "s": {        result: 0,    },    "x": {        result: 0,    },}//function init(str, format) {    datestr = str;    dateformat = format;    index = 0;    char = null;    for(var i in types) {        types[i].result = 0;    }}function getWordByNum(type, label, num) {    //    return types[type][label][num];}function getNumByWord(type, label, word) {    var words = types[type].words[label];    for(var i = 0; i < words.length; i++) {        if(word.match(words[i])) return i;    }    return 0;}function charNext(num) {    if(num) index += num - 1;    char = index < dateformat.length ? dateformat[index++] : null;    return char;}function charBack(num) {    if(num) index -= num - 1;    char = index > 0 ? dateformat[--index] : null;    return char;}// 如果字符是數字形式,從這里解析function matchNum() {    var type = char;    var len = getTypeLength(); // 獲取type長度,如YYYY,len為4    var str = splitStrByLength(len); // 減掉datestr前len個字符,并返回前len個字符    saveToResult(type, str); // 將截取到的字符串保存在結果中}// 如果字符是詞語形式,從這里解析function matchWord() {    trimHead(); // 這個函數中有多個trimHead,說明如[M:week]可以寫成[ M : week ]的形式    charNext();    if(!isType()) {        throwErr();    }    var type = char;    trimHead();    match(":");    trimHead();    var label = getLabel();    match("]");    var str = splitStrByChar(getBreakChar());    saveToResult(type, getNumByWord(type, label, str));}function saveToResult(type, str) {    //    types[type].result = parseInt(str);}function getTypeLength() {    var len = dateformat.substring(index - 1).match(char + "+")[0].length;    charNext(len - 1);    return len;}function isType() {    //    return types[char];}function getLabel() {    str = "";    while(charNext()) {        if(char == null) throwErr();        if(char == ']') break;         str += char;    }    charBack();    return str;}function getBreakChar() {    //    return dateformat[index];}function splitStrByLength(len) {    var str = datestr.substring(0, len);    datestr = datestr.substring(len);    return str;}function splitStrByChar(breakChar) {    var end = breakChar ? datestr.indexOf(breakChar) : datestr.length;    var str = datestr.substring(0, end);    datestr = datestr.substring(end);    return str;}function compareChar() {    if(char == datestr[0]) {        datestr = datestr.substring(1);        return true;    }else {        throwErr("未匹配到字符" + char);    }}function trimHead() {    while(charNext() == " ") {}    charBack();}function match(c) {    if(charNext() == c) {        return true;    }else {        throwErr("缺少標識符;" + c);    }}function throwErr(err) {    if(!err) err = "";    var str = "出錯位置:" + (index - 1).toString() + " /"" + char + "/"。" + err;    throw str;}function getResult() {    var json = {};    for(var i in types) {        json[i] = types[i].result;    }    return json;}function parse(datestr, dateformat) {    init(datestr, dateformat);    try {        while(charNext()) {            if(!char) break;            if(char == "[") {                matchWord();                continue;            }            if(!isType()) compareChar();            else matchNum();        }    }catch(err) {        console.log(err);    }    var json = getResult()    //console.log(json);    var date = new Date();    date.setYear(json['Y']);    date.setMonth(json['M']);    date.setDate(json['D']);    date.setHours(json['h']);    date.setMinutes(json['m']);    date.setSeconds(json['s']);    date.setMilliseconds(json['x']);    return date;}Date.prototype.parse = parse;Date.prototype.format = function (fmt) { //author: meizz ,這個函數來自博友,非本人編寫    var o = {        "M+": this.getMonth() + 1, //月份         "D+": this.getDate(), //日         "h+": this.getHours(), //小時         "m+": this.getMinutes(), //分         "s+": this.getSeconds(), //秒        "q+": Math.floor((this.getMonth() + 3) / 3), //季度         "x+": this.getMilliseconds() //毫秒     };    if (/(Y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));    for (var k in o)    if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));    return fmt;}//*****************************************************})();


上一篇:js閉包的理解

下一篇:WebSocket簡單應用

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 丽江市| 娱乐| 太湖县| 留坝县| 东光县| 亚东县| 双鸭山市| 宾川县| 林芝县| 崇左市| 大丰市| 历史| 越西县| 休宁县| 永定县| 镇巴县| 泸定县| 公安县| 镇赉县| 垣曲县| 新绛县| 广汉市| 兴国县| 永和县| 新田县| 松桃| 东山县| 永城市| 定兴县| 定边县| 资兴市| 满城县| 武汉市| 崇仁县| 常山县| 泸西县| 新河县| 卓资县| 西平县| 图木舒克市| 美姑县|