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

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

jQuery插件之——簡單日歷

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

最近在研究js插件的開發,以前看大神們,對插件都是信手拈來,隨便玩弄,感覺自己要是達到那種水平就好了,就開始自己研究插件開發了。研究了一段時間之后,就開始寫了自己的第一個日歷插件,由于是初學插件開發,代碼的可讀性可能有點差,希望各位大神可以多提點意見,以后維護代碼,讓這個插件更加的完整。下面就貼出代碼。

首先,給插件來個整體的div容器

<div class="y-total"></div>

本人習慣給容器取class或id名時,加上自己獨特的前綴,這樣,有助于識別自己的代碼,也避免與其他同事的樣式沖突。

然后就是開始寫樣式,可以根據自己的需求來調整樣式

 1 .y-total{height:auto;border:1px solid #666;} 2     .y-total .return-btn{height:23px;} 3     .y-total .return-btn>div{border-right: 1px solid #033;border-bottom: 1px solid #033;color: #666;font-family: "Microsoft Yahei",PMingLiU,Verdana,Arial,Helvetica,sans-serif} 4     .y-total .return-btn>div:nth-child(3){border-right:0px;} 5     .y-total .PRev-btn{cursor: pointer;width:25%;float: left;text-align: center;} 6     .y-total .time{cursor: pointer;float:left;width:49%;text-align: center;} 7     .y-total .next-btn{cursor: pointer;float:right;width:25%;text-align: center;} 8     .y-total .y-stop{position: absolute;margin-left: 6px;background-color: red;color: #fff;} 9     .y-total #datatab{clear:both;width:100%;}10     .y-total #datatab td {height:30px;font-family: "Microsoft Yahei",PMingLiU,Verdana,Arial,Helvetica,sans-serif;color: #666;border: 1px solid #D2D2D2;font-size: 14px;text-align: center;}

第三步,就是插件的代碼了

  1 <script>  2      (function($){  3         var Beautifier = function(vals,options){  4           this.vals = vals;  5           this.defaults = {  6             "width":"300px"  7           }  8           this.p = $.extend({},this.defaults,options);   9           this.$div = $("<div class='return-btn'></div>"); 10           this.prev = $("<div class='prev-btn'>前一頁</div>"); 11           this.time = $("<div class='time'></div>"); 12           this.next = $("<div class='next-btn'>后一頁</div>"); 13           this.tab = $("<table id='datatab'><tr></tr></table>"); 14         } 15  16         Beautifier.prototype = { 17           getDate : function(){ 18              var vals = this.vals; 19              var t = this.time.attr("class"); 20              var tab = this.tab.attr("id"); 21              this.$div.append(this.prev,this.time,this.next); 22              $(this.p.$this).append(this.$div,this.tab).width(this.p.width); 23              var i = getInfo(vals); 24              $("."+t).text(vals.year+"-" + i[0]+"-" + i[1]); 25              $(".prev-btn,.next-btn").click(function(){returnAction($(this),t,vals,tab)});     26              setDateInfo(tab); 27              init(vals,tab); 28           } 29         } 30         /*加載時將日期放入td中*/ 31         function init(vals,tab){ 32            var w = new Date(vals.year+","+vals.month+","+1).getDay()//獲取本月第一天是星期幾 33            var l =(w==0?6:w-1) + new Date(vals.year,vals.month,0).getDate();//需要鋪上td的個數 34            var t = Math.ceil(l/7); 35            for(var i=0; i<t; i++){ 36              $("#"+tab).append("<tr class='y-tr'></tr>"); 37            } 38            $(".y-tr").each(function(){ 39               for(var i=0; i<7; i++){ 40                 $(this).append("<td></td>"); 41               } 42            }) 43            setvalue(vals,new Date(vals.year,vals.month,0).getDate(),w); 44         } 45         function setvalue(val,l,w){ 46            for(var i=1;i<l+1;i++){ 47              var space = w==0?i+7-1+6:i+w-1+6; 48              $("td").eq(space).text(i); 49              if(i == val.day){ 50                $("td").eq(space).CSS("color","red");  51              } 52            } 53         } 54         function getInfo(vals){ 55            var info = []; 56            info.push(vals.month > 9 ? vals.month : "0" + vals.month); 57            info.push(vals.day > 9 ? vals.day : "0" + vals.day); 58            return info; 59         } 60  61         function setDateInfo(tab){ 62           var m = ["","一","二","三","四","五","六","日"]; 63           for(var i=1; i<8; i++){ 64              $("#"+tab).find("tr:eq(0)").append("<td>星期"+m[i]+"</td>"); 65           } 66         } 67         /*上一頁,下一頁的點擊事件*/ 68         function returnAction($this,t,val,tab){ 69            if($this.attr("class") == "prev-btn"){ 70                if(val.month < 2){ 71                   val.month =12; 72                   val.year-=1; 73                }else{ 74                   val.month-=1; 75                } 76             }else if($this.attr("class") == "next-btn"){ 77                if(val.month > 11){ 78                   val.month =1; 79                   val.year+=1; 80                }else{ 81                   val.month+=1; 82                } 83             }    84            var v = getInfo(val); 85            $("."+t).text(val.year+"-"+v[0]+"-"+v[1]); 86            $(".y-tr").remove(); 87            init(val,tab); 88         }  89  90         $.fn.work = function(options){ 91           var t = new Date(); 92           var DateVal = { 93             "year" : t.getFullYear(), 94             "month" : t.getMonth()+1, 95             "day" : t.getDate() 96           } 97           var objs = new Beautifier(DateVal,options);  98           objs.getDate(); 99         }100      })(jQuery)101   </script>

那么,插件就差不多完成了,現在只需要調用插件的方法就可以了

1 <script>2      $(".y-total").work({3        "$this" : ".y-total",4        "width" : "200px",//控制容器的寬度5       });6 </script>

效果如圖:


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 顺义区| 紫金县| 漳州市| 瓮安县| 华蓥市| 新疆| 平度市| 东方市| 衡阳市| 咸宁市| 华安县| 白沙| 永城市| 讷河市| 寿阳县| 泸定县| 龙游县| 华亭县| 扬中市| 廉江市| 鸡西市| 平江县| 航空| 时尚| 吉木乃县| 茌平县| 广东省| 定边县| 南皮县| 滨海县| 灵石县| 宁蒗| 通州区| 四川省| 武夷山市| 毕节市| 灌南县| 海口市| 汉中市| 霍林郭勒市| 镇赉县|