不错的一个日期输入 动态

所属分类: 网络编程 / JavaScript 阅读数: 395
收藏 0 赞 0 分享

复制代码 代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>日期控件</title>
<script>
var agt = navigator.userAgent.toLowerCase();
var OldTextBox;
function DateSeter(obj){
    var parent=obj.parentNode;

    var selYear=document.createElement('SELECT');
    selYear.id='LoftyYear';
    parent.insertBefore(selYear,obj);
    var selMonth=document.createElement('SELECT');
    selMonth.id='LoftyMonth';
    parent.insertBefore(selMonth,obj);
    var selDay=document.createElement('SELECT');
    selDay.id='LoftyDay';
    parent.insertBefore(selDay,obj);
    var btnSubmit=document.createElement('BUTTON');
    btnSubmit.style.width='22px';
    parent.insertBefore(btnSubmit,obj);
    btnSubmit.id='LoftyBtn';
    for(s in btnSubmit)
    {
//document.write(s+'<br />');
    }
    btnSubmit.textContent='OK';
    btnSubmit.value='OK';
    al(btnSubmit,'click','Restore()');
    OldTextBox=obj;
    parent.removeChild(obj);

    var now=new Date();
    var cYear=now.getFullYear();
    SetCurrentYear(selYear,cYear);
    al(selYear,'change','SetCurrentYear(document.getElementById(\'LoftyYear\'))');
    al(selMonth,'change','SetDay(null,null)');
    for(i=1;i<=12;i++)
    {
        var op=new Option(i,i);
        selMonth.options.add(op);
    }
    var cMonth=now.getMonth()+1;
    SetDay(cYear,cMonth);
    selDay.selectedIndex=now.getDate()-1;
}
function Restore()
{
    var yy=document.getElementById('LoftyYear');
    var mm=document.getElementById('LoftyMonth');
    var d=document.getElementById('LoftyDay');
    var btn=document.getElementById('LoftyBtn');
    var time=yy.options[yy.selectedIndex].value+'-'+mm.options[mm.selectedIndex].value+'-'+d.options[d.selectedIndex].value;
    OldTextBox.value=time;
    var parent=yy.parentNode;
    parent.insertBefore(OldTextBox,yy);
    parent.removeChild(yy);
    parent.removeChild(mm);
    parent.removeChild(d);
    parent.removeChild(btn);
}
function SetDay(year,month)
{
    if(year==null){
        var yy=document.getElementById('LoftyYear');
        var mm=document.getElementById('LoftyMonth');
        year=Math.round(yy.options[yy.selectedIndex].value);
        month=Math.round(mm.options[mm.selectedIndex].value);
    }
    var date=new Date(year,month,1);
    date.setDate(0);
    var maxdate=date.getDate();
    var obj=document.getElementById('LoftyDay');
    var seldate=obj.selectedIndex;
    if(obj.options.length>0){
        if(Math.round(obj.options[obj.selectedIndex].value)>maxdate)
        {
            seldate=maxdate-1;
        }
    }
        reAppendSelect(obj,1,maxdate,seldate+1);
}
function SetCurrentYear(selecter,currYear)
{
    if(currYear==null){
        currYear=Math.round(selecter.options[selecter.selectedIndex].value);
    }
    reAppendSelect(selecter,currYear-10,currYear+10,currYear);
}
function reAppendSelect(selecter,startIndex,endIndex,selIndex)
{
    while(selecter.options.length>0)
    {
        selecter.removeChild(selecter.options[selecter.options.length-1]);
    }
    for(i=startIndex;i<=endIndex;i++)
    {
        var op=new Option(i,i);
        selecter.options.add(op);
        op.selected=(selIndex==i);
    }
}
function al(obj,lissener,func){
    if(agt.indexOf('firefox')!=-1){
        obj.addEventListener(lissener,function(){eval(func);},false);
    }else{
        obj.attachEvent('on'+lissener,function(){eval(func);});
    }
}
</script>
</head>
<body>
<input onclick="DateSeter(this);" />
</body>
</html>


精简只有年:
复制代码 代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>日期控件</title>
<script>



var agt = navigator.userAgent.toLowerCase();
var OldTextBox;
function DateSeter(obj){
    var parent=obj.parentNode;

    var selYear=document.createElement('SELECT');
    selYear.id='LoftyYear';
    parent.insertBefore(selYear,obj);
/*
    var btnSubmit=document.createElement('BUTTON');
    btnSubmit.style.width='32px';
    parent.insertBefore(btnSubmit,obj);
    btnSubmit.id='LoftyBtn';

    btnSubmit.textContent='OK';
    btnSubmit.value='OK';
    al(btnSubmit,'click','Restore()');
*/    
    OldTextBox=obj;
    parent.removeChild(obj);
    var defaultValue = obj.value;
    var now=new Date();
    var cYear=now.getFullYear();
    SetCurrentYear(selYear,cYear,defaultValue);
    al(selYear,'change','Restore(obj)');
}
function Restore()
{
OldTextBox.value = arguments[0].value;
var yy=document.getElementById('LoftyYear');
var parent=yy.parentNode;
parent.insertBefore(OldTextBox,yy);
parent.removeChild(yy);
/*
    var yy=document.getElementById('LoftyYear');
    var btn=document.getElementById('LoftyBtn');
    var time=yy.options[yy.selectedIndex].value;
    OldTextBox.value=time;
    var parent=yy.parentNode;
    parent.insertBefore(OldTextBox,yy);
    parent.removeChild(yy);
    parent.removeChild(btn);
*/
}
function SetCurrentYear(selecter,currYear)
{
    if(currYear==null){
        currYear=Math.round(selecter.options[selecter.selectedIndex].value);
    }
    var dv = arguments[2];
    reAppendSelect(selecter,1901,2001,currYear,dv);
}
function reAppendSelect(selecter,startIndex,endIndex,selIndex)
{
    while(selecter.options.length>0)
    {
        selecter.removeChild(selecter.options[selecter.options.length-1]);
    }
    for(i=startIndex;i<=endIndex;i++)
    {
        var op=new Option(i,i);
        selecter.options.add(op);
        if(arguments[4]!=""){
            if(i==arguments[4])
                op.selected=true;
        }else{
            if (i==endIndex)
                op.selected=true;
        }
    }

}
function al(obj,lissener,func){
    if(agt.indexOf('firefox')!=-1){
        obj.addEventListener(lissener,function(){eval(func);},false);
    }else{
        obj.attachEvent('on'+lissener,function(){eval(func);});
    }
}


</script>
</head>

<body>
<input onclick="DateSeter(this);" />
</body>
</html>

更多精彩内容其他人还在看

layui table 复选框跳页后再回来保持原来选中的状态示例

今天小编就为大家分享一篇layui table 复选框跳页后再回来保持原来选中的状态示例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
收藏 0 赞 0 分享

Vue-Cli项目优化操作的实现

这篇文章主要介绍了Vue-Cli项目优化操作,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

解决包含在label标签下的checkbox在ie8及以下版本点击事件无效果兼容的问题

这篇文章主要介绍了解决包含在label标签下的checkbox在ie8及以下版本点击事件无效果兼容的问题,本文给大家总结的非常详细,需要的朋友可以参考下
收藏 0 赞 0 分享

vue 父组件通过v-model接收子组件的值的代码

这篇文章主要介绍了vue 父组件通过v-model接收子组件的值的代码,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

vue 全局环境切换问题

小编在开发使经常会碰到全局切换问题,今天小编给大家带来一篇教程给大家介绍vue 全局环境切换问题,感兴趣的朋友一起看看吧
收藏 0 赞 0 分享

element-ui 本地化使用教程详解

这篇文章主要介绍了element-ui 本地化使用教程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

在Vue项目中,防止页面被缩放和放大示例

今天小编就为大家分享一篇在Vue项目中,防止页面被缩放和放大示例,具有很好的参考 价值,希望对大家有所帮助。一起跟随小编过来看看吧
收藏 0 赞 0 分享

vue h5移动端禁止缩放代码

今天小编就为大家分享一篇vue h5移动端禁止缩放代码,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
收藏 0 赞 0 分享

Vue 3.0双向绑定原理的实现方法

这篇文章主要为大家详细介绍了Vue 3.0双向绑定原理的实现方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

nest.js 使用express需要提供多个静态目录的操作方法

这篇文章主要介绍了nest.js 使用express需要提供多个静态目录的操作,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享
查看更多