HTML5中如何实现input[type='date']自定义样式与日历校验功能
短信预约 -IT技能 免费直播动态提醒
这篇文章给大家分享的是有关HTML5中如何实现input[type='date']自定义样式与日历校验功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
1.日历控件自定义样式
HTML5提供了日历控件功能,缩减了开发时间,但有时它的样式确实不如人意,我们可以根据下面的代码自行修改。
建议:复制下面的代码段,单独建立一个css文件,方便我们修改。
::-webkit-datetime-edit { padding: 1px;}
::-webkit-datetime-edit-fields-wrapper { background-color: #fff; }
::-webkit-datetime-edit-text { color: #333; padding: 0 .5em; }
::-webkit-datetime-edit-year-field { color: #333; }
::-webkit-datetime-edit-month-field { color: #333; }
::-webkit-datetime-edit-day-field { color: #333; }
::-webkit-inner-spin-button { visibility: hidden; }
::-webkit-calendar-picker-indicator {
border: 1px solid #ccc;
border-radius: 2px;
box-shadow: inset 0 1px #fff, 0 1px #eee;
background-color: #eee;
background-image: -webkit-linear-gradient(top, #f0f0f0, #e6e6e6);
color: #666;
}
::-webkit-clear-button {
}
2.日期校验功能
终止日期不能小于起始日期,日期选择范围为7天,其余时间段为不可选。
注:下述代码段利用Jquery原理
//转换时间类型为 yyyy-mm-dd
function FormatDate (strTime) {
var date = new Date(strTime);
var formatedMonth = ("0" + (date.getMonth() + 1)).slice(-2);
var formatedDate = ("0" + (date.getDate())).slice(-2);
return date.getFullYear()+"-"+formatedMonth+"-"+formatedDate;
}
//开始时间
$("#keyword_time_min").change(function(){
var d1=new Date($(this).val()); //获取当前时间
var d2=new Date(d1);
// d2.setFullYear(d2.getFullYear()+1); //当前时间+1年
d2.setDate(d2.getDate()+7); //当前时间+7天
d2=FormatDate(d2); //转换d2为YYYY-MM-DD格式
$("#keyword_time_max").attr("max",d2); //最大时间为d2
$("#keyword_time_max").attr("min",$(this).val()); //最小时间为当前时间
});
//终止时间
$("#keyword_time_max").change(function(){
var d3=new Date($(this).val());
var d4=new Date(d3);
// d4.setFullYear(d4.getFullYear()-1);
d4.setDate(d4.getDate()-7); //当前时间-7天
d4=FormatDate(d4);
$("#keyword_time_min").attr("min",d4);
$("#keyword_time_min").attr("max",$(this).val());
});
感谢各位的阅读!关于“HTML5中如何实现input[type='date']自定义样式与日历校验功能”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341