Jquery日歷插件制作簡(jiǎn)單日歷
在頁面開發(fā)中,經(jīng)常遇到需要用戶輸入日期的操作。通常的做法是,提供一個(gè)文本框(text),讓用戶輸入,然后,編寫代碼驗(yàn)證輸入的數(shù)據(jù),檢測(cè)其是否是日期類型。這樣比較麻煩,同時(shí),用戶輸入日期的操作也不是很方便,影響用戶體驗(yàn)。如果使用jQuery UI中的datepicker(日歷)插件,這些問題都可以迎刃而解。該插件調(diào)用的<span style="color:#cc66cc;"><strong>語法格式</strong></span>如下:
$(“.selector”).datepicker(options);
其中”.selector”表示DOM元素,一般指文本框,由于該插件的作用是提供日期選擇,因此常與一個(gè)文本框綁定,將選擇后的日期顯示在該文本框中,選擇options是一個(gè)對(duì)象與前面插件中的options一樣,通過改變其參數(shù)對(duì)應(yīng)的值,從而實(shí)現(xiàn)插件功能的變化,在datepicker插件中,選擇options常用參數(shù)如下
1、changeMonth 設(shè)置一個(gè)布爾值,如果wietrue,則可以在標(biāo)題處出現(xiàn)一個(gè)下拉選擇框,可以選擇月份,默認(rèn)值為false
2、changeYear 設(shè)置一個(gè)布爾值,如果為true,則可以在標(biāo)題處出現(xiàn)一個(gè)下拉選擇框,可以選擇年份,默認(rèn)為false
3、showButtonPanel 設(shè)置一個(gè)布爾值,如果為true,則在日期的下面顯示一個(gè)面板,其中有兩個(gè)按鈕;一個(gè)為“今天”,另一個(gè)按鈕為“關(guān)閉”,默認(rèn)值為false,表示不顯示
4、closeText 設(shè)置關(guān)閉按鈕上的文字信息,這項(xiàng)設(shè)置的前提是,showButtonPanel的值必須為true,否則顯示不了效果
5、dateFormat 設(shè)置顯示在文本框(text)中的日期格式,可設(shè)置為{dateFormat,'yy-mm-dd'},表示日期的格式為年-月-日,如2012-10-1
6、defaultDate 設(shè)置一個(gè)默認(rèn)日期值,如{defaultDate+7},表示,彈出日期選擇窗口后,默認(rèn)的日期是在當(dāng)前日期上加上7天
7、showAnim 設(shè)置顯示彈出或隱藏日期選擇窗口的方式。可以設(shè)置的方式有,“show”、“sildeDown”、“fadeln”后者“”,表示沒有彈出日期選擇窗口的方式
8、showWeek 設(shè)置一個(gè)布爾值,如果為true,則可以顯示每天對(duì)應(yīng)的星期,默認(rèn)值為false
9、yearRange 設(shè)置年份的范圍
最近在研究js插件的開發(fā),以前看大神們,對(duì)插件都是信手拈來,隨便玩弄,感覺自己要是達(dá)到那種水平就好了,就開始自己研究插件開發(fā)了。研究了一段時(shí)間之后,就開始寫了自己的第一個(gè)日歷插件,由于是初學(xué)插件開發(fā),代碼的可讀性可能有點(diǎn)差,希望各位大神可以多提點(diǎn)意見,以后維護(hù)代碼,讓這個(gè)插件更加的完整。
下面就貼出代碼。
首先,給插件來個(gè)整體的div容器
<div class="y-total"></div>
本人習(xí)慣給容器取class或id名時(shí),加上自己獨(dú)特的前綴,這樣,有助于識(shí)別自己的代碼,也避免與其他同事的樣式?jīng)_突。
然后就是開始寫樣式,可以根據(jù)自己的需求來調(diào)整樣式
.y-total{height:auto;border:px solid #;}
.y-total .return-btn{height:px;}
.y-total .return-btn>div{border-right: px solid #;border-bottom: px solid #;color: #;font-family: "Microsoft Yahei",PMingLiU,Verdana,Arial,Helvetica,sans-serif}
.y-total .return-btn>div:nth-child(){border-right:px;}
.y-total .prev-btn{cursor: pointer;width:%;float: left;text-align: center;}
.y-total .time{cursor: pointer;float:left;width:%;text-align: center;}
.y-total .next-btn{cursor: pointer;float:right;width:%;text-align: center;}
.y-total .y-stop{position: absolute;margin-left: px;background-color: red;color: #fff;}
.y-total #datatab{clear:both;width:%;}
.y-total #datatab td {height:px;font-family: "Microsoft Yahei",PMingLiU,Verdana,Arial,Helvetica,sans-serif;color: #;border: px solid #DDD;font-size: px;text-align: center;}
第三步,就是插件的代碼了
<script>
(function($){
var Beautifier = function(vals,options){
this.vals = vals;
this.defaults = {
"width":"px"
}
this.p = $.extend({},this.defaults,options);
this.$div = $("<div class='return-btn'></div>");
this.prev = $("<div class='prev-btn'>前一頁</div>");
this.time = $("<div class='time'></div>");
this.next = $("<div class='next-btn'>后一頁</div>");
this.tab = $("<table id='datatab'><tr></tr></table>");
}
Beautifier.prototype = {
getDate : function(){
var vals = this.vals;
var t = this.time.attr("class");
var tab = this.tab.attr("id");
this.$div.append(this.prev,this.time,this.next);
$(this.p.$this).append(this.$div,this.tab).width(this.p.width);
var i = getInfo(vals);
$("."+t).text(vals.year+"-" + i[]+"-" + i[]);
$(".prev-btn,.next-btn").click(function(){returnAction($(this),t,vals,tab)});
setDateInfo(tab);
init(vals,tab);
}
}
/*加載時(shí)將日期放入td中*/
function init(vals,tab){
var w = new Date(vals.year+","+vals.month+","+).getDay()//獲取本月第一天是星期幾
var l =(w==?:w-) + new Date(vals.year,vals.month,).getDate();//需要鋪上td的個(gè)數(shù)
var t = Math.ceil(l/);
for(var i=; i<t; i++){
$("#"+tab).append("<tr class='y-tr'></tr>");
}
$(".y-tr").each(function(){
for(var i=; i<; i++){
$(this).append("<td></td>");
}
})
setvalue(vals,new Date(vals.year,vals.month,).getDate(),w);
}
function setvalue(val,l,w){
for(var i=;i<l+;i++){
var space = w==?i+-+:i+w-+;
$("td").eq(space).text(i);
if(i == val.day){
$("td").eq(space).css("color","red");
}
}
}
function getInfo(vals){
var info = [];
info.push(vals.month > ? vals.month : "" + vals.month);
info.push(vals.day > ? vals.day : "" + vals.day);
return info;
}
function setDateInfo(tab){
var m = ["","一","二","三","四","五","六","日"];
for(var i=; i<; i++){
$("#"+tab).find("tr:eq()").append("<td>星期"+m[i]+"</td>");
}
}
/*上一頁,下一頁的點(diǎn)擊事件*/
function returnAction($this,t,val,tab){
if($this.attr("class") == "prev-btn"){
if(val.month < ){
val.month =;
val.year-=;
}else{
val.month-=;
}
}else if($this.attr("class") == "next-btn"){
if(val.month > ){
val.month =;
val.year+=;
}else{
val.month+=;
}
}
var v = getInfo(val);
$("."+t).text(val.year+"-"+v[]+"-"+v[]);
$(".y-tr").remove();
init(val,tab);
}
$.fn.work = function(options){
var t = new Date();
var DateVal = {
"year" : t.getFullYear(),
"month" : t.getMonth()+,
"day" : t.getDate()
}
var objs = new Beautifier(DateVal,options);
objs.getDate();
}
})(jQuery)
</script>
那么,插件就差不多完成了,現(xiàn)在只需要調(diào)用插件的方法就可以了
<script>
$(".y-total").work({
"$this" : ".y-total",
"width" : "px",//控制容器的寬度
});
</script>
效果如圖:

- 基于jquery實(shí)現(xiàn)日歷簽到功能
- jQuery EasyUI API 中文文檔 - Calendar日歷使用
- 為開發(fā)者準(zhǔn)備的10款最好的jQuery日歷插件
- jQuery簡(jiǎn)單實(shí)現(xiàn)日歷的方法
- jQuery寫的日歷(包括日歷的樣式及功能)
- jQuery 聯(lián)動(dòng)日歷實(shí)現(xiàn)代碼
- .net mvc頁面UI之Jquery博客日歷控件實(shí)現(xiàn)代碼
- php+mysql+jquery實(shí)現(xiàn)日歷簽到功能
- JQuery日歷插件My97DatePicker日期范圍限制
- 基于jquery實(shí)現(xiàn)日歷效果
相關(guān)文章
JQuery實(shí)現(xiàn)左右滾動(dòng)菜單特效
這篇文章主要介紹了jquery實(shí)現(xiàn)左右滑動(dòng)菜單效果代碼,涉及jquery鼠標(biāo)事件相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09
jquery觸發(fā)a標(biāo)簽跳轉(zhuǎn)事件示例代碼
本文為大家詳細(xì)介紹下如何使用jquery觸發(fā)a標(biāo)簽的跳轉(zhuǎn)事件,感興趣的朋友可以參考下哈,希望對(duì)大家有所幫助2013-07-07
使用jquery實(shí)現(xiàn)div的tab切換實(shí)例代碼
以前使用js代碼來寫的簡(jiǎn)單效果現(xiàn)在用jQ來寫,具體實(shí)現(xiàn)如下,感興趣的朋友可以參考下哈2013-05-05
jquery中常用的SET和GET$(”#msg”).html循環(huán)介紹
jquery中常用的SET和GET$(”#msg”).html循環(huán)想必大家并不陌生吧,本文整理了一些,感興趣的朋友可以參考下2013-10-10
jQuery實(shí)現(xiàn)鼠標(biāo)拖動(dòng)圖片功能
這篇文章主要介紹了jQuery實(shí)現(xiàn)鼠標(biāo)拖動(dòng)圖片功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03
JavaScript 學(xué)習(xí)筆記之一jQuery寫法圖片等比縮放以及預(yù)加載
以前對(duì)于JavaScript總是在用到的時(shí)候在頁面上寫幾個(gè)函數(shù),基本沒考慮到函數(shù)的封裝與重用,最近有個(gè)項(xiàng)目可能對(duì)于這方面要求有點(diǎn)高,所以就研究了下類似jQuery的封裝2012-06-06
jQuery查找節(jié)點(diǎn)方法完整實(shí)例
這篇文章主要介紹了jQuery查找節(jié)點(diǎn)方法,結(jié)合完整實(shí)例形式分析了jQuery針對(duì)DOM節(jié)點(diǎn)屬性的相關(guān)操作技巧,需要的朋友可以參考下2016-09-09

