【问题标题】:User input - difference of two dates in Javascript用户输入 - Javascript中两个日期的差异
【发布时间】:2018-02-06 13:52:21
【问题描述】:

我是 JS 的初学者。我有日期的用户输入值。我想在几天内得到差异。尝试了几种方法,都没有奏效。 将输入类型用作数字,但它不适用于 03092017 - 29082017 之类的示例,它输出的是数字差而不是日期。

function resetForm() {
  location.reload();
}

function dates() {
  var n_Date = document.getElementById('ddate').value;
  var e_Date = document.getElementById('cdate').value;
  var nDate = new Date(n_Date);
  var eDate = new Date(e_Date);
  var nMonth = n_Date.getMonth();
  var eMonth = eDate.getMonth();
  var nYear = nDate.getFullYear();
  var eYear = eDate.getFullYear();
  var Years = Math.abs(nYear - eYear);
  var Months = Math.abs(nMonth - eMonth);
  var Dates = Math.abs(nDate - eDate);
  var fDate = Dates + Months + Years;

  if (fDate <= 7) {
    alert("You have: " + fDate + " days to return the book");
  } else if (eDate > 7) {
    var g = (fDate * 50);
    alert("Overdue by: " + fDate + " days fee is: " + g);
  }

}
<form id="myform">
  <table>
    <tr>
      <td>Book Returning Due Date:</td>
      <td><input type="date" id="ddate" placeholder="dd/mm/yyyy"></td>
    </tr>
    <tr>
      <td>Current Date:</td>
      <td><input type="date" id="cdate" placeholder="dd/mm/yyyy"></td>
    </tr>
    <tr>
      <td><input type="button" onclick="dates();" value="Check for Due"> </td>
      <td><input type="button" id="reset" onclick="resetForm()" value="Reset"></td>
    </tr>

  </table>
</form>

【问题讨论】:

标签: javascript html


【解决方案1】:

尝试为此使用moment.js

var startDate = moment("13.04.2016", "DD.MM.YYYY");
var endDate = moment("28.05.2016", "DD.MM.YYYY");
var result = 'Diff: ' + endDate.diff(startDate, 'days');
  
  console.log(result);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://momentjs.com/downloads/moment.js"></script>

【讨论】:

  • 感谢它的工作。新的时刻。非常迷人。干杯!
【解决方案2】:

查看下面的示例解决方案以获得两个日期之间的天数差异

var nDate  = new Date(n_Date);
var eDate  = new Date(e_Date);
var diffInDays = nDate.getDate()-eDate.getDate()

这是带有示例数据的解决方案:

 var nDate  = new Date("2017-08-29");
    var eDate  = new Date("2017-08-25");
    var diffInDays = nDate.getDate()-eDate.getDate()
console.log(diffInDays);

【讨论】:

  • 如果用户更改月份会怎样?
【解决方案3】:

你可以这样做:

var startDate = new Date(2017,08,29);
var endDate = new Date(2017,09,15);
var oneDayMilliseconds = 3600*24*1000;

var daysLeft = Math.round(Math.abs((startDate.getTime() - endDate.getTime())/(oneDayMilliseconds)));

console.log("Days left: " + daysLeft);

希望对你有帮助:)

【讨论】:

  • 非常感谢您的大力帮助。我也能够以这种方式做到这一点。 (parseInt((pickdt- dropdt) / (24 * 3600 * 1000))) 并得到了进行数学运算的值,如 link
  • 欢迎您@Tithira。是的,如果你不想要依赖,这是一个很好的解决方案。
猜你喜欢
  • 2015-09-14
  • 1970-01-01
  • 1970-01-01
  • 2013-07-17
  • 1970-01-01
  • 2013-02-01
  • 2016-08-16
相关资源
最近更新 更多