js封装日历控件
最终效果

代码实现
<script>
$(function () {
$(".j-calendar").calendar({
date: '2017-08-03',
callback: function () {
var date = new Date($(this).attr("year"), $(this).attr("month"), $(this).attr("day"));
alert(date);
},
loadinfo: function () {
var liList = $(".j-calendar").find('li');
$.each(liList, function(i, item) {
if ($(item).attr("day") == "") {
$(item).find(".m-CYwork").html("¥2580");
}
});
}
});
});
</script>
/*
* @author:Cheryl
* @made:2015-12-31
*/ (function (window, $, undefined) {
$.canlendarClass = {
defaults: {
date: new Date(),
canderShwType: "default",
callback: function () { },
loadinfo: function () { }
},
hrtnDay: ,
hrtnOne: ,
hrtnLast: ,
title: "<ul class='m-CYul-tit m-CYul'><li>周日</li><li>周一</li><li>周二</li><li>周三</li><li>周四</li><li>周五</li><li>周六</li></ul>",
canComplete: function (d) {
this.canDayone(d);
this.canDay(d);
},
canDayone: function (d) {
var dayone = new Date(d.getFullYear(), d.getMonth(), );
this.hrtnOne = dayone.getDay();//0 1 2 3 4 5 6
this.canDay(d);
var dayLast = new Date(d.getFullYear(), d.getMonth(), this.hrtnDay);
this.hrtnLast = dayLast.getDay();
},
canDay: function (d) {
var year = d.getFullYear();
var month = d.getMonth() + ;
//判断拥有多少天
switch (month) {
case :; case :; case :; case :; case :; case :; case : this.hrtnDay = ; break;
case :; case :; case :; case : this.hrtnDay = ; break;
case : if (year % == && year % != || year % == ) { this.hrtnDay = ; } else { this.hrtnDay = ; }; break;
default: console.log("请您输入正确的月份。"); break;
}
},
}
$.extend($.fn, {
calendar: function (option) {
if ($(this)[] == null || $(this)[] == undefined) {
return;
};
$.canlendarClass.defaults.canderShwType = "default";
for (var i = ; i < ; i++) {
//参数合并
$.canlendarClass.defaults = $.extend($.canlendarClass.defaults, $.extend(option || {}) || {});
var d = new Date(add(new Date($.canlendarClass.defaults.date) || new Date(), "m", i));
//参数计算
$.canlendarClass.canComplete(d);
//添加
$(this).addChild(d);
}
//给这些li添加方法
$(this).children("li").click(function () {
$(this).addClass("active").siblings("li").removeClass("active");
});
//调用加载数据的方法
$.canlendarClass.defaults.loadinfo();
$(this).children("li").on("click", $.canlendarClass.defaults.callback);
//样式添加|当天标蓝
if ($.canlendarClass.defaults.canderShwType == "small") {
$(this).addClass("s-CY m-CYul");
/*var eqli=$.canlendarClass.hrtnDay<=$.canlendarClass.defaults.day?$.canlendarClass.hrtnDay:$.canlendarClass.defaults.day;
$(this).children("li[day="+eqli+"]").addClass("active");*/
} else {
$(this).addClass("d-CY m-CYul");
};
},
addChild: function (d) { // $(this).html("");
$(this).append(
"<div class=\"yearMonth\">" +
"<h2><span id=\"year\">" + d.getFullYear() + "年</span><span id=\"month\">" + parseInt(d.getMonth() + ) + "月</span></h2>" +
"</div>" +
$.canlendarClass.title);
for (var i = ; i < $.canlendarClass.hrtnOne; i++) {
$(this).append('<li class="noday"></li>');
}; var strsld = "";
switch ($.canlendarClass.defaults.canderShwType) {
case "default":
strsld = "<ul class='m-CYwork'></ul>";
break;
case "small":
strsld = "";
break;
default:
break;
}
for (var i = ; i < $.canlendarClass.hrtnDay; i++) {
$(this).append('<li year="' + (d.getFullYear()) + '" month="' + (d.getMonth() + ) + '" day="' + (i + ) + '"><span>' + (i + ) + '</span>' + strsld + '</li>');
};
for (var i = ; i < ( - $.canlendarClass.hrtnLast) ; i++) {
$(this).append('<li class="noday"></li>');
};
var eqli = $.canlendarClass.hrtnDay <= $.canlendarClass.defaults.day ? $.canlendarClass.hrtnDay : $.canlendarClass.defaults.day;
$(this).children("li[day=" + new Date().getDate() + "]:first").addClass("m-CYtoday"); },
});
})(window, jQuery); var add = function (datetiem, strInterval, Number) {
var dtTmp = datetiem;
switch (strInterval) {
case 's': return new Date(Date.parse(dtTmp) + ( * Number));
case 'n': return new Date(Date.parse(dtTmp) + ( * Number));
case 'h': return new Date(Date.parse(dtTmp) + ( * Number));
case 'd': return new Date(Date.parse(dtTmp) + ( * Number));
case 'w': return new Date(Date.parse(dtTmp) + (( * ) * Number));
case 'q': return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number * , dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());
case 'm': return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number, , dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());
case 'y': return new Date((dtTmp.getFullYear() + Number), dtTmp.getMonth(), dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());
}
}
js封装日历控件的更多相关文章
- 2.23 js处理日历控件(修改readonly属性)
2.23 js处理日历控件(修改readonly属性) 前言 日历控件是web网站上经常会遇到的一个场景,有些输入框是可以直接输入日期的,有些不能,以我们经常抢票的12306网站为例,详细讲解如 ...
- JS实现日历控件选择后自动填充
最近在做人事档案的项目,在做项目的初期对B/S这块不是很熟悉,感觉信心不是很强,随着和师哥同组人员的交流后发现,调试程序越来越好了,现在信心是倍增,只要自己自己踏实的去研究.理解代码慢慢的效果就出来了 ...
- JS编写日历控件(支持单日历 双日历 甚至多日历等)
前言: 最近几天都在研究日历控件编写,当然前提我要说明下,当然看过别人写的源码 所以脑子一热 就想用自己的编码方式 来写一套可扩展性 可维护性 性能高点的代码控件出来,就算练习练习下,所以前几天晚上下 ...
- selenium+Python(Js处理日历控件)
日历控件是web网站上经常会遇到的一个场景,有些输入框是可以直接输入日期的,有些不能,以我们经常抢票的12306网站为例,详细讲解如何解决日历控件为readonly属性的问题. 基本思路:先用js去掉 ...
- Selenium2学习(十七)-- js处理日历控件(修改readonly属性)
前言 日历控件是web网站上经常会遇到的一个场景,有些输入框是可以直接输入日期的,有些不能,以我们经常抢票的12306网站为例,详细讲解如何解决日历控件为readonly属性的问题. 基本思路:先用j ...
- selenium webdriver——JS操作日历控件
一般的日期控件都是input标签下弹出来的,如果使用webdriver 去设置日期, 1. 定位到该input 2. 使用sendKeys 方法 比如 但是,有的日期控件是readonly的 比如12 ...
- selenium - js日历控件处理
# 13. js处理日历控件 ''' 在web自动化的工程中,日历控制大约分为两种: 1. 可以直接输入日期 2. 通过日历控件选择日期 基本思路: 利用js去掉readonly属性,然后直接输入时间 ...
- TWaver初学实战——如何在TWaver属性表中添加日历控件?
在日期输入框中添加日历控件,是一种非常流行和实用的做法.临渊羡鱼不如退而写代码,今天就看看在TWaver中是如何实现的. 资源准备 TWaver的在线使用文档中,就有TWaver Proper ...
- 自己用js写的两个日历控件
前一阵写了两个日历控件,做了简单的封装,发出来共朋友们参考. 第一个日历控件,条状的日历. (使用方法:调用initBarTime(id,evn),第一个参数是要渲染div的id,第二个参数是点击日期 ...
随机推荐
- HDU-1090-A+B for Input-Output Practice (II)(骗訪问量的)
A+B for Input-Output Practice (II) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/327 ...
- ZOJ 2604 Little Brackets DP
DP: 边界条件:dp[0][j] = 1 递推公式:dp[i][j] = sum{dp[i-k][j] * dp[k-1][j-1] | 0<k≤i} i对括号深度不超过j的,能够唯一表示为( ...
- Spark-Dependency
1.Spark中採用依赖关系(Dependency)表示rdd之间的生成关系.Spark可利用Dependency计算出失效的RDD.在每一个RDD中都存在一个依赖关系的列表 private var ...
- HTML-HTML5+CSS3权威指南阅读(三、CSS3)
不同的浏览器(包括-moz-代表的Mozilla Firefox, -ms-代表的Microsoft Internet Explorer等)厂商在发布正式版本之前之前, 试验各自对CSS3新特性的实现 ...
- 使用css3属性transition实现页面滚动
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-type" content ...
- rownum使用说明
参考:http://www.blogjava.net/conans/articles/219693.html 参考:http://www.blogjava.net/freeman1984/archiv ...
- context.Request.Files post 上传问题件
[无刷新上传] 要实现文件上传,form必须设置几个属性:1.action:设为要处理数据的页面地址:2.method:设为"post":3.enctype/encoding:必须 ...
- 点滴积累【C#】---C#实现下载word
效果: 思路: 简单的有两种方式下载,一种是流下载,一种是WriteFile下载.以下是使用WriteFile下载. 代码: protected void LinkButton1_Click(obje ...
- Unity向量投影使用
官方例图 测试: code: public Transform point1; public Transform point2; public Transform humanPoint; public ...
- [python小记]使用lxml修改xml文件,并遍历目录
这次的目的是遍历目录,把目标文件及相应的目录信息更新到xml文件中.在经过痛苦的摸索之后,从python自带的ElementTree投奔向了lxml.而弃用自带的ElementTree的原因就是,na ...