简体   繁体   English

在JS中分别将datetime转换为日期时间格式

[英]Convert datetime to date and time format separately in JS

Currently I have this html for my calendar目前我的日历有这个 html

<!--Grid column-->
<div class="col-md-6">
<div class="md-form mb-0">
    <input placeholder="Selected date" data-toggle="datepicker" type="text" id="myDate" name="myDate" class="form-control datepicker">
    <label for="myDate" id="dateLabel">Estimated Start Date</label>
</div>
</div>
 <!--Grid column-->

Currently I have this目前我有这个

var est_start_date = $(this).attr('data-esd');

and the value I place it to the textbox using this code以及我使用此代码将其放置到文本框中的值

$('#myDate').val(est_start_date);

which contains value like this其中包含这样的值

在此处输入图像描述

As you can notice the data includes the time also如您所见,数据还包括时间

How can I format the datetime to something like this MM/DD/YYYY如何将日期时间格式化为这样的MM/DD/YYYY

在此处输入图像描述

Also separate the time to this format也将时间分隔为这种格式

在此处输入图像描述

let date=new Date(document.querySelector('#myDate').value)让 date=new Date(document.querySelector('#myDate').value)

Date part ===> date.toLocaleDateString().日期部分 ===> date.toLocaleDateString()。

Time part ====> date.toLocaleTimeString() for the time part.时间部分 ====> date.toLocaleTimeString() 用于时间部分。

from below answer:从下面的答案:

Split the date and time in two elements 将日期和时间拆分为两个元素

You can use the javascript date object to get the required format.您可以使用 javascript 日期 object 来获取所需的格式。 Use this,用这个,

 function formatDate(date) { const arr = [date.getMonth() + 1, date.getDate(), date.getFullYear()] var hours = date.getHours(); var minutes = date.getMinutes(); var ampm = hours >= 12? 'PM': 'AM'; hours = hours % 12; hours = hours? hours: 12; // the hour '0' should be '12' minutes = minutes < 10? '0'+minutes: minutes; var strTime = hours + ':' + minutes + ' ' + ampm; var date = arr.join("/"); return date + " " +strTime; } console.log(formatDate(new Date));

Use this to convert your date to required format,使用它来将您的日期转换为所需的格式,

 function formatDate(date) { date = date.split(" "); let dateOne = date[0]; let time = date[1]; time = time.split(":"); time.forEach((val,index)=>{ if(val.length <2){ val = "0" + val; time[index] = val; } }) time = time.join(":"); let str = `${dateOne}T${time}.000Z`; let offset = (new Date()).getTimezoneOffset()*60*1000; date = new Date( (new Date(`${dateOne}T${time}.000Z`)).getTime() + offset); const arr = [date.getMonth() + 1, date.getDate(), date.getFullYear()] var hours = date.getHours(); var minutes = date.getMinutes(); var ampm = hours >= 12? 'PM': 'AM'; hours = hours % 12; hours = hours? hours: 12; // the hour '0' should be '12' minutes = minutes < 10? '0'+minutes: minutes; var strTime = hours + ':' + minutes + ' ' + ampm; var date = arr.join("/"); return date + " " +strTime; } let date = '2019-10-21 1:41:00'; console.log(formatDate(date));

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM