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,第二个参数是点击日期 ...
随机推荐
- iOS UITableView获取特定位置的cell
代码地址如下:http://www.demodashi.com/demo/13307.html 一.tableView双级联动 以上两种效果比较类似,实现的关键在于都是需要获得在滑动过程中滑动到tab ...
- mybatis加入条件
根据http://www.cnblogs.com/friends-wf/p/3799315.html搭建的环境 User.xml加入的 if where判断的 <!-- 根据条件查询一个用户 - ...
- MVC项目发布到IIS遇到的问题
MVC4 + .NET Framework 4.5 +Windows Server 2008+ IIS7.5 + 4.0集成模式池 ,发布后可能会遇到404.0 或者403.14错误,在web.con ...
- Linux软件包安装和卸载
安装软件包的三种方法 1.rpm.yum.源码包 2.yum会把依赖的包都安装上 rpm包介绍 3.rmp报名组成结构:yum-3.4.3-132.el7.centos.0.1.noarch.rpm ...
- 图解SQL inner join、left join、right join、full outer join、union、union all的区别
转于:http://justcoding.iteye.com/blog/2006487 这是一篇来自Coding Horror的文章. SQL的Join语法有很多:有inner的,有outer的,有l ...
- atitit.项目设计模式---ioc attilax总结
atitit.项目设计模式---ioc attilax总结 1. .IOC的之前 1 2. ioc后的实现 1 3. 认识引入IOC框架的缺点, 2 4. 自己实现ioc 3 4.1. ioc框架的实 ...
- TextView中超链接拦截
TextView中的超链接点击时,其实是通过Intent方式的,因此会调用Activity中的startActivity(Intent intent)方法,所以可在此方法中做些简单的拦截操作 例如拦截 ...
- UVA Problem B: Fire!
Problem B: Fire! Joe works in a maze. Unfortunately, portions of the maze have caught on fire, and t ...
- iOS开发中的内存管理
一.为什么要进行内存管理 系统资源有限,iOS会为每一个执行的程序分配30M的内存,超过20M会收到内存警告,超过30M将会终止应用程序.因此,要及时回收一些不须要再继续使用的内存空间,比方回收一些不 ...
- git三种模式及常用命令
Git的三种重要模式,分别是已提交.已修改.已暂存. 已提交(committed):表示数据文件已经顺利提交到Git数据库中. 已修改(modified):表示数据文件已经被修改,但未被保存到Git数 ...