zoukankan      html  css  js  c++  java
  • HTML5 input date属性引起的探索——My97DatePicker(日期选择插件)

    不得不说H5的input date属性真的好用,之前我写的http://www.cnblogs.com/tu-0718/p/6729274.html 这篇博客里面也有提到,不过虽然移动端对H5的支持还是很好的,但是PC端浏览器对H5的支持就很让人无奈了。然后最近遇到一个需求:需要一个开始时间和结束时间,默认显示年月,如下图:

    第一反应想到的是H5的input date属性,因为兼容性问题无奈放弃,然后发现了一个挺好用的插件:DatePicker

    注:在使用此插件时需要注意,DatePicker插件需要的不仅仅是js文件,而是整个文件夹都需要,如下图:

      如果你把里面的js文件单独提出来引入的话是没有效果的,控制台会提示找不到此js文件,这个文件的路径是不能改的,能改的只有文件夹的名字。

      此插件调用WdatePicker() 方法默认显示年月日如下图:

      

      如果你只想显示年月,onclick="WdatePicker({dateFmt:'yyyy-MM'})" 即可,如下图

      

      

      本来到这里就应该结束了,不过后面需求又加了一个,说是要给开始时间和结束时间设置一个默认时间,经测试,此插件并没有相应的方法可以办到。

      然后我就想到了一个方法,用jquery获取到开始时间和结束时间元素的值,然后调用原生JS new Date()方法,在用toLocaleDateString()转一次

      代码如下:

        $("#beginDate").val(new Date().toLocaleDateString());
        $("#endDate").val(new Date().toLocaleDateString());
     
      效果如下图:
        
      
       
     
     
      本以为这样应该可以了吧,结果又说不能要日,只要年月,(我的内心是崩溃的), 原生Date方法也没有这个方法。焦急之余向大神求助,大神就是给力啊,
      给了一个自己写的方法,只要调用这个方法,然后在用substr()截取就可以了,代码如下:
      
      $("#beginDate").val(GetDateStr().substr(0,7));
          $("#endDate").val(GetDateStr().substr(0,7));
          function GetDateStr(AddYear,AddMonth,AddDay) {
                AddYear?AddYear:AddYear=0;
                AddMonth?AddMonth:AddMonth=0;
                AddDay?AddDay:AddDay=0;
                var dd = new Date();
                dd.setFullYear(dd.getFullYear()+AddYear);
                dd.setMonth(dd.getMonth()+AddMonth);
                dd.setDate(dd.getDate()+AddDay);
                var y = dd.getFullYear();
                var m = dd.getMonth()+1;
                var d = dd.getDate();
                return y+"-"+m;
          }
      效果如下图:
      
     
     

      附: 我就一条龙服务做到底吧,在附上一段代码,主要用于判断日期(起始时间不能大于结束时间 / 不能直接选择结束时间,需要先选择起始时间) 

    $(document).ready(function(){
             var createDateBegin = $("#beginDate");
             var createDateEnd = $("#endDate");
             $(createDateEnd).blur(function(){
                 if(createDateEnd.val()!="" && createDateBegin.val()!=""&&createDateEnd.val()<createDateBegin.val()){
                     alert('开始时间不能大于结束时间!');
                     $(createDateEnd).val("");
                     return;
                 }
                 if((createDateBegin).val()==""){
                     alert('请选择起始时间!');
                     $(createDateEnd).val("");
                     return;
                 }
                 if((createDateBegin).val()!=""){
                     return;
                 }
             });
            $(createDateBegin).blur(function(){
                 if(createDateEnd.val()!="" && createDateBegin.val()!=""&&createDateEnd.val()<createDateBegin.val()){
                     alert('开始时间不能大于结束时间!');
                     $(createDateEnd).val("");    
                     return;
                 }
                 if($(createDateEnd).val()!=""){
                    return;
                 }
             });
            });
        
  • 相关阅读:
    scala中的注解
    scala中的表达式
    scala中枚举
    spark sql建表的异常
    hive和sequoiadb对接的问题
    java IO的总结
    Spark的序列化
    pentaho和spark-sql对接
    英语口语练习系列-C28-海滨-辨别身份-悬崖边的树
    2018-12-4-今日总结
  • 原文地址:https://www.cnblogs.com/tu-0718/p/6920408.html
Copyright © 2011-2022 走看看