jquery日历插件——laydate的使用

主要使用的是layui组件库中的laydate组件。附:

layui.laydathttps://www.layui.com/laydate/

HTML部分

   <div class="card-calendar">
        <!-- 日历选择器 -->
        <input type="text" class="inputBox " readonly="" value="" id="datetimepicker" data-date-format="yyyy-mm-dd">
        <p class="minus">—</p>
        <input type="text" class="inputBox " readonly="" value="" id="datetimepicker2" data-date-format="yyyy-mm-dd">
        <!-- 日历选择器 -->
   </div>

依赖资源

  <script src="js/jquery-1.9.1.min.js"></script>
  <script src="laydate/laydate.js"></script>

JS部分

  <!-- 日历插件 -->
  <script>
    // var value = new Date(),
    var nowValue = formatTime();
    console.log("value" + nowValue);
    var startDate = laydate.render({
      elem: '#datetimepicker',
      format: 'yyyy年MM月dd日',
      value: nowValue,
      isInitValue: true,
      theme: '#108ee9',
      trigger: 'click',
      done: function (value, date) {
        console.log(value); //得到日期生成的值,如:2017-08-18
        console.log(date); //得到日期时间对象:{year: 2017, month: 8, date: 18, hours: 0, minutes: 0, seconds: 0}
        console.log(endDate); //得结束的日期时间对象,开启范围选择(range: true)才会返回。对象成员同上。
        if (value != "") {
          date.month = date.month - 1;
          endDate.config.min = date;
        } else {
          endDate.config.min = startDate.config.min;
        }
      },
    });
    var endDate = laydate.render({
      elem: '#datetimepicker2',
      format: 'yyyy年MM月dd日',
      isInitValue: true,
      trigger: 'click',
      value: nowValue,
      theme: '#108ee9',

      done: function (value, date) {
        if (value != "") {
          date.month = date.month - 1;
          startDate.config.max = date;
        } else {
          startDate.config.max = endDate.config.max;
        }
      }
    });
  </script>

elem: input元素

format: 格式

trigger: 仅仅可以点击,不可手动输入

value:默认值

theme: 主题色

相对来说,完成的内容是区间的选择,所以在选择完成之后执行done方法,然后通过max和min的变量的赋值来控制区间的显示。

日期格式化使用

  <!-- 日期格式化 -->
  <script>
    function formatTime() {
      var newdate = new Date();
      var nowyear = newdate.getFullYear();
      var nowmonth = newdate.getMonth() + 1;
      if (nowmonth >= 1 && nowmonth <= 9) {
        nowmonth = "0" + nowmonth;
      }
      var nowDate = newdate.getDate();
      var formattime = nowyear + "年" + nowmonth + "月" + nowDate + "日";
      return formattime;
    }
  </script>

在设置默认值的时候需要进行格式转换才能有效赋值,否则input中设置的默认值会为空。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值