最も簡単なJSカレンダーコントロール


このコントロールは最新のグーグルブラウザ、最新の火狐ブラウザ、そしてIE 8でテストに成功し、互換性が良い.拡張しやすく、呼び出しが簡単で、以降のプロジェクトの日付コントロールは自分で書くことができます.
もっと勉強して交流して私のブログにアクセスしてください(http://www.webczw.com/)
function choose_date_czw(date_id,objtd){
if(date_id=="choose_date_czw_close"){
document.getElementById("choose_date_czw_id").style.display="none";
return;
}

if(objtd!=undefined){
if(objtd=="choose_date_czw_empty"){
document.getElementById(date_id).value="";
}else{
var year1 = document.getElementById("choose_date_czw_year").value;
var month1 = document.getElementById("choose_date_czw_month").value;
document.getElementById(date_id).value=year1+"-"+month1+"-"+objtd.innerHTML;
}
document.getElementById("choose_date_czw_id").style.display="none";
return;
}
var nstr=new Date(); //
if(document.getElementById("choose_date_czw_year")!=null){
var year = document.getElementById("choose_date_czw_year").value;
var month = document.getElementById("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 (year%100==0 ? res=(year%400==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>&nbsp;<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>&nbsp;<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>&nbsp;</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.getElementById("choose_date_czw_id")==null){
var obj = document.getElementById(date_id);
var odiv = document.createElement("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.appendChild(odiv);
}else{
document.getElementById("choose_date_czw_id").style.display="block";
document.getElementById("choose_date_czw_id").innerHTML=dstr;
}
}

 
呼び出し方法は次のとおりです.
 
<input type="text" id="add_date" onclick="choose_date_czw('add_date')"/>

実行結果は次のとおりです.
最简约JS日历控件