简约JS日历控件 实例代码


Posted in Javascript onJuly 12, 2013

运行结果如下:

简约JS日历控件 实例代码

<script type="text/javascript" language="javascript">
function choose_date_czw(date_id,objtd){
if(date_id=="choose_date_czw_close"){
    document.getElementByIdx_x_x("choose_date_czw_id").style.display="none";
    return;
}
if(objtd!=undefined){
    if(objtd=="choose_date_czw_empty"){
        document.getElementByIdx_x_x(date_id).value="";
    }else{
        var year1 = document.getElementByIdx_x_x("choose_date_czw_year").value;
        var month1 = document.getElementByIdx_x_x("choose_date_czw_month").value;
        document.getElementByIdx_x_x(date_id).value=year1+"-"+month1+"-"+objtd.innerHTML;
    }
    document.getElementByIdx_x_x("choose_date_czw_id").style.display="none";
    return;
}
var nstr=new Date(); //当前
if(document.getElementByIdx_x_x("choose_date_czw_year")!=null){
    var year = document.getElementByIdx_x_x("choose_date_czw_year").value;
    var month = document.getElementByIdx_x_x("choose_date_czw_month").value;
    var str=year+"/"+month+"/1";
    nstr=new Date(str); //当前
}
var ynow=nstr.getFullYear(); //年份
var mnow=nstr.getMonth(); //月份
var dnow=nstr.getDate(); //今日日期
var n1str=new Date(ynow,mnow,1); //当月第一天
var firstday=n1str.getDay(); //当月第一天星期几
function is_leap(year) {
   return (year0==0 ? res=(year@0==0 ? 1 : 0) : res=(year%4==0 ? 1: 0));
}
var dstr="<select id=\"choose_date_czw_year\" onchange=\"choose_date_czw('"+date_id+"')\">";
for(var y=1901;y<2050;y++){
    if(y==ynow){
        dstr+="<option value='"+y+"' selected>"+y+"</option>"
    }else{
        dstr+="<option value='"+y+"'>"+y+"</option>"
    }
}
dstr+="</select> <select id=\"choose_date_czw_month\" onchange=\"choose_date_czw('"+date_id+"')\">";
for(var m=1;m<13;m++){
    if(parseInt(mnow+1)==m){
        dstr+="<option value='"+m+"' selected>"+m+"</option>"
    }else{
        dstr+="<option value='"+m+"'>"+m+"</option>"
    }
}
dstr+="</select> <span style='cursor:pointer;' onclick=\"choose_date_czw('choose_date_czw_close')\">关闭</span>|<span style='cursor:pointer;' onclick=\"choose_date_czw('"+date_id+"','choose_date_czw_empty')\">清空</span>";
//一三五七八十腊(十二月),三十一日永不差;四六九冬(十一月)三十日,唯有二月二十八(闰年二十九).
var m_days = new Array(31,28+is_leap(ynow),31,30,31,30,31,31,30,31,30,31);
var tr_str=Math.ceil((m_days[mnow] + firstday)/7);
dstr+="<table border='0' cellpadding='5' cellspacing='0'><tr><td>日</td><td>一</td><td>二</td><td>三</td><td>四</td><td>五</td><td>六</td></tr>";
var dqdate=new Date(); //当前
for(i=0;i<tr_str;i++) { //外层for语句- tr标签
   dstr+="<tr>";
   for(k=0;k<7;k++) { //内层for语句- td标签
      idx=i*7+k; //表格单元的自然序号
      date_str=idx-firstday+1; //计算日期
     if(date_str<=0 || date_str>m_days[mnow]){
          dstr+="<td> </td>";
     }else{
        if(ynow==dqdate.getFullYear() && mnow==dqdate.getMonth() && dqdate.getDate()==date_str){
            dstr+="<td onmouseover=\"this.style.backgroundColor='#6FF'\" onmouseout=\"this.style.backgroundColor='#fff'\" onclick=\"choose_date_czw('"+date_id+"',this)\" style='cursor:pointer; background-color:#6FF;'>"+date_str+"</td>";
        }else{
            dstr+="<td onmouseover=\"this.style.backgroundColor='#6FF'\" onmouseout=\"this.style.backgroundColor='#fff'\" onclick=\"choose_date_czw('"+date_id+"',this)\" style='cursor:pointer;'>"+date_str+"</td>";
        }
     }
   }
   dstr+="</tr>";
}
dstr+="</table>";
if(document.getElementByIdx_x_x("choose_date_czw_id")==null){
var obj = document.getElementByIdx_x_x(date_id);
var odiv = document_createElement_x_x("div");
odiv.id="choose_date_czw_id";
odiv.innerHTML=dstr;
odiv.style.position="absolute";
odiv.style.border="1px #0CF solid";
odiv.style.fontSize="12px";
odiv.style.zIndex=99999;
odiv.style.top=obj.offsetTop+obj.offsetHeight+"px";
odiv.style.left=obj.offsetLeft+"px";
document.body.a(odiv);
}else{
    document.getElementByIdx_x_x("choose_date_czw_id").style.display="block";
    document.getElementByIdx_x_x("choose_date_czw_id").innerHTML=dstr;
}
}
</script>
<input type="text" id="add_date" onclick="choose_date_czw('add_date')"/>
Javascript 相关文章推荐
js 方法实现返回多个数据的代码
Apr 30 Javascript
基于jquery循环map功能的代码
Feb 26 Javascript
Javascript Boolean、Nnumber、String 强制类型转换的区别详细介绍
Dec 13 Javascript
javascript使用定时函数实现跳转到某个页面
Dec 25 Javascript
浅谈利用JavaScript进行的DDoS攻击原理与防御
Jun 04 Javascript
javascript数据类型详解
Feb 07 Javascript
vue2.0 与 bootstrap datetimepicker的结合使用实例
May 22 Javascript
js链表操作(实例讲解)
Aug 29 Javascript
JavaScript设计模式之享元模式实例详解
Jan 17 Javascript
微信小程序实现简单的select下拉框
Nov 23 Javascript
vue递归实现树形组件
Jul 15 Vue.js
vue el-table实现递归嵌套的示例代码
Aug 14 Vue.js
javascript中自定义对象的属性方法分享
Jul 12 #Javascript
javascript中的toFixed固定小数位数 简单实例分享
Jul 12 #Javascript
javascript中的parseInt和parseFloat区别
Jul 12 #Javascript
JS文本框追加多个下拉框的值的简单实例
Jul 12 #Javascript
JS代码同步文本框内容的实例方法
Jul 12 #Javascript
jquery 获取标签名(tagName)示例代码
Jul 11 #Javascript
js jquery获取随机生成id的服务器控件的三种方法
Jul 11 #Javascript
You might like
web server使用php生成web页面的三种方法总结
2013/10/28 PHP
php版本的cron定时任务执行器使用实例
2014/08/19 PHP
PHP中的output_buffering详细介绍
2014/09/27 PHP
PHP生成json和xml类型接口数据格式
2015/05/17 PHP
Yii控制器中操作视图js的方法
2016/07/04 PHP
PHP简单预防sql注入的方法
2016/09/27 PHP
PHP会话操作之cookie用法分析
2016/09/28 PHP
php使用str_shuffle()函数生成随机字符串的方法分析
2017/02/17 PHP
PHP7多线程搭建教程
2017/04/21 PHP
使用PHP json_decode可能遇到的坑与解决方法
2017/08/03 PHP
12行javascript代码绘制一个八卦图
2015/04/02 Javascript
简单了解JavaScript操作XPath的一些基本方法
2016/06/03 Javascript
运用js教你轻松制作html音乐播放器
2020/04/17 Javascript
Angularjs中数据绑定的实例详解
2017/08/25 Javascript
详解如何在项目中使用jest测试react native组件
2018/02/09 Javascript
vue 项目打包通过命令修改 vue-router 模式 修改 API 接口前缀
2018/06/13 Javascript
实例介绍JavaScript中多种组合继承
2019/01/20 Javascript
jQuery 函数实例分析【函数声明、函数表达式、匿名函数等】
2020/05/19 jQuery
详细讲解Python中的文件I/O操作
2015/05/24 Python
Python处理JSON数据并生成条形图
2016/08/05 Python
python解决Fedora解压zip时中文乱码的方法
2016/09/18 Python
将python代码和注释分离的方法
2018/04/21 Python
使用TensorFlow实现SVM
2018/09/06 Python
python实现微信防撤回神器
2019/04/29 Python
Python 70行代码实现简单算式计算器解析
2019/08/30 Python
pytorch实现保证每次运行使用的随机数都相同
2020/02/20 Python
sklearn和keras的数据切分与交叉验证的实例详解
2020/06/19 Python
boostrap modal 闪现问题的解决方法
2020/09/01 HTML / CSS
美国鞋类购物网站:Shiekh Shoes
2016/08/21 全球购物
Vince官网:全球著名设计师品牌,休闲而优雅的服饰
2017/01/15 全球购物
新员工试用期自我鉴定
2014/04/17 职场文书
小班幼儿评语大全
2014/04/30 职场文书
项目申请汇报材料
2014/08/16 职场文书
行政经理岗位职责
2015/04/15 职场文书
酒吧七夕情人节宣传语
2015/11/24 职场文书
nginx+lua单机上万并发的实现
2021/05/31 Servers