今天有空就開寫一個Calendar日曆,在網上看到一個牛人寫的JavaScript日期格式化的代碼,看了一會有點暈。代碼奉上:
/**<br /> * @param d the delimiter<br /> * @param p the pattern of your date<br /> * @author meizz<br /> * @author kimsoft add w+ pattern<br /> */<br />Date.prototype.format = function(style) {<br />var o = {<br />"M+" : this.getMonth() + 1, //month<br />"d+" : this.getDate(), //day<br />"h+" : this.getHours(), //hour<br />"m+" : this.getMinutes(), //minute<br />"s+" : this.getSeconds(), //second<br />"w+" : "/u65e5/u4e00/u4e8c/u4e09/u56db/u4e94/u516d".charAt(this.getDay()), //week<br />"q+" : Math.floor((this.getMonth() + 3) / 3), //quarter<br />"S" : this.getMilliseconds() //millisecond<br />}<br />if (/(y+)/.test(style)) {<br />style = style.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));<br />}<br />for(var k in o){<br />if (new RegExp("("+ k +")").test(style)){<br />style = style.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length));<br />}<br />}<br />return style;<br />};
看到上面代碼有RegExp.$1,很茫然。查了一下才知道:
$1…$9是RegExp的一個屬性, $1…$9:表示第n組匹配的結果,這個在Regex裡有多個以()分組時有用。
JScript中String對象與Regex有關的操作有一個叫replace,可是要如何在replace中使用Regex匹配的結果呢?
這時候我們就需要用到“匹配變數”了,匹配變數用於表示正則匹配的結果,以下是匹配變數的說明:
$& -- 表示全部匹配組匹配的結果,最後再囉嗦一次,匹配組就是Regex的()分組
$$ -- 表示$字元,因為匹配變數用掉了$字元,所以需要轉義
$n -- 類似前面的$1…$9,表示第n組匹配的結果
$nn -- 很簡單就是第nn組匹配的結果
$` -- 就是前面提到過的leftContext,比如abcdefg被匹配出了d那麼abc就是它的leftContext了
$' -- 和上面符合很接近不要看錯了!,這個就是rightContext了