星空2020 2023-02-17 13:03 采纳率: 64.1%
浏览 49
已结题

Layui table field如何利用templet计算时间差,显示倒计时

Layui table field显示动态倒计时时间差,如何实现。
当出库时间outtime为空时,将接收时间receivetime+6小时-当前实时时间得到动态的倒计时(例如"倒计时:5.5小时")。当出库时间不为空时,用出库时间-接收时间,得到时效。


```java
<script>
layui.use(['table', 'util'], function(){
  var table = layui.table;
      var laydate = layui.laydate;
      var form = layui.form;
      var $ = layui.jquery;
      var util = layui.util //时间戳转日期格式
    
  var tableIns = table.render({
    elem: '#test'
    ,url: '.ordder.php' //数据接口
    ,toolbar:'#toolbarDemo'
    ,loading:true
    ,height:'full-20'
    ,skin:''
    ,size:''
    ,page: true //开启分页
    ,cols: [[ //表头
      {type: 'checkbox', fixed: 'left',align:'center' ,width:'80'}
      ,{field: 'id', fixed: 'left',title: 'ID', width:'80', sort: false ,align:'center'}
      ,{field: 'receivetime', title: '接单时间', width: '150',align:'center'}
      ,{field: 'outtime', title: '出库时间', width: '150',align:'center'}
      ,{field: 'shixiao',fixed:'right', title: '时效(H)', width: '80',align:'center'}
    //如何利用templet,当出库时间为空时,将接收时间+6小时-当前实时时间得到动态的倒计时(例如5.5小时)。当出库时间不为空时,用出库时间-接收时间,得到时效。
     ,{fixed: 'right', title: '操作',toolbar: '#operation',align:'center', width: '110'}
    ]]
    ,where:{
        }
        , page: {layout: ['prev', 'page', 'next', 'skip', 'count', 'limit', 'refresh']} //page false
        , limits: [50,100,150,200,250,300,350,400,450,500]
        , limit: 50 //每页默认显示的数量
     });

```

  • 写回答

2条回答 默认 最新

  • allyfireshen 2023-02-17 13:50
    关注

    可参考如下:

    
    layui.use(['table', 'util'], function(){
      var table = layui.table;
          var laydate = layui.laydate;
          var form = layui.form;
          var $ = layui.jquery;
          var util = layui.util //时间戳转日期格式
        
      var tableIns = table.render({
        elem: '#test'
        ,url: '.ordder.php' //数据接口
        ,toolbar:'#toolbarDemo'
        ,loading:true
        ,height:'full-20'
        ,skin:''
        ,size:''
        ,page: true //开启分页
        ,cols: [[ //表头
          {type: 'checkbox', fixed: 'left',align:'center' ,width:'80'}
          ,{field: 'id', fixed: 'left',title: 'ID', width:'80', sort: false ,align:'center'}
          ,{field: 'receivetime', title: '接单时间', width: '150',align:'center'}
          ,{field: 'outtime', title: '出库时间', width: '150',align:'center'}
          ,{field: 'shixiao',fixed:'right', title: '时效(H)', width: '80',align:'center'templet: d => {
            if (!d.outtime) {
              let nowTime =  new Date(); // 获取当前时间
              let receivetime = new Date((new Date(d.receivetime)).getHours() + 6); // 接收时间receivetime+6小时
              let dateDiff = nowTime.getTime() - receivetime.getTime(); // 计算接收时间receivetime+6小时-当前实时时间
              let dayDiff  =  Math.floor(dateDiff / (24 * 3600 * 1000)); // 计算出相差天数
              let leave1=dateDiff%(24*3600*1000)    //计算天数后剩余的毫秒数
              let hours=Math.floor(leave1/(3600*1000))//计算出小时数
              hours = dayDiff  *  24 + hours;
              let leave2=leave1%(3600*1000)    //计算小时数后剩余的毫秒数
              let minutes=Math.floor(leave2/(60*1000)) // 计算相差分钟数
              if  (minutes > 30) hours += ".5";
              return "倒计时:" + hours
            } else {
              let outtime = newDate(d.outtime);
              let receivetime = new Date(d.receivetime);
              let dateDiff = outtime.getTime() - receivetime.getTime(); // 计算接收时间receivetime+6小时-当前实时时间
              let dayDiff  =  Math.floor(dateDiff / (24 * 3600 * 1000)); // 计算出相差天数
              let leave1=dateDiff%(24*3600*1000)    //计算天数后剩余的毫秒数
              let hours=Math.floor(leave1/(3600*1000))//计算出小时数
              hours = dayDiff  *  24 + hours;
              let leave2=leave1%(3600*1000)    //计算小时数后剩余的毫秒数
              let minutes=Math.floor(leave2/(60*1000)) // 计算相差分钟数
              if  (minutes > 30) hours += ".5";
              return "时效:" + hours
            }
           }}
        //如何利用templet,当出库时间为空时,将接收时间+6小时-当前实时时间得到动态的倒计时(例如5.5小时)。当出库时间不为空时,用出库时间-接收时间,得到时效。
         ,{fixed: 'right', title: '操作',toolbar: '#operation',align:'center', width: '110'}
        ]]
        ,where:{
            }
            , page: {layout: ['prev', 'page', 'next', 'skip', 'count', 'limit', 'refresh']} //page false
            , limits: [50,100,150,200,250,300,350,400,450,500]
            , limit: 50 //每页默认显示的数量
         });
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月28日
  • 已采纳回答 2月20日
  • 创建了问题 2月17日

悬赏问题

  • ¥20 c语言写的8051单片机存储器mt29的模块程序
  • ¥60 求直线方程 使平面上n个点在直线同侧并且距离总和最小
  • ¥50 java算法,给定试题的难度数量(简单,普通,困难),和试题类型数量(单选,多选,判断),以及题库中各种类型的题有多少道,求能否随机抽题。
  • ¥50 rk3588板端推理
  • ¥250 opencv怎么去掉 数字0中间的斜杠。
  • ¥15 这种情况的伯德图和奈奎斯特曲线怎么分析?
  • ¥250 paddleocr带斜线的0很容易识别成9
  • ¥15 电子档案元素采集(tiff及PDF扫描图片)
  • ¥15 flink-sql-connector-rabbitmq使用
  • ¥15 zynq7015,PCIE读写延时偏大