我目前试图显示用户的时间而不显示秒。是否有一种方法,我可以这样做使用Javascript的.toLocaleTimeString()?
做这样的事情:
var date = new Date();
var string = date.toLocaleTimeString();
将显示用户的时间与每个单位,例如,目前显示为3:39:15 PM。我是否能够显示相同的字符串,只是没有秒?(例如下午3时39分)
我目前试图显示用户的时间而不显示秒。是否有一种方法,我可以这样做使用Javascript的.toLocaleTimeString()?
做这样的事情:
var date = new Date();
var string = date.toLocaleTimeString();
将显示用户的时间与每个单位,例如,目前显示为3:39:15 PM。我是否能够显示相同的字符串,只是没有秒?(例如下午3时39分)
当前回答
我也一直在寻找这个问题的解决方案,以下是我最终想到的:
function getTimeStr() {
var dt = new Date();
var d = dt.toLocaleDateString();
var t = dt.toLocaleTimeString();
t = t.replace(/\u200E/g, '');
t = t.replace(/^([^\d]*\d{1,2}:\d{1,2}):\d{1,2}([^\d]*)$/, '$1$2');
var result = d + ' ' + t;
return result;
}
你可以在这里试试:http://jsfiddle.net/B5Zrx/
\u200E是我在一些IE版本上看到的格式化字符(它是unicode从左到右的标记)。
我假设如果格式化的时间包含类似“XX:XX:XX”的内容,那么它一定是带秒的时间,我删除了最后一部分,如果我没有找到这个模式,什么都没有改变。相当安全,但在一些奇怪的情况下,有可能会留下几秒钟。
我只是希望没有locale会改变格式化时间部分的顺序(例如,使它ss:mm:hh)。这个从左到右的标记让我有点紧张,这就是为什么我不删除从右到左的标记(\u202E) -我更喜欢在这种情况下不找到匹配,在这种情况下让时间格式化为秒。
其他回答
我认为最初的问题可以很容易地用迄今为止被忽略的东西来回答:简单的字符串分割。返回的时间是一个文本字符串,只需在“:”分隔符上拆分它,并按您想要的方式重新组装字符串。没有插件,没有复杂的脚本。你看:
var myVar=setInterval(function(){myTimer()},1000);
function myTimer() {
var d = new Date();
currentNow = d.toLocaleTimeString();
nowArray = currentNow.split(':');
filteredNow = nowArray[0]+':'+nowArray[1];
document.getElementById("demo").innerHTML = filteredNow;
}
我也一直在寻找这个问题的解决方案,以下是我最终想到的:
function getTimeStr() {
var dt = new Date();
var d = dt.toLocaleDateString();
var t = dt.toLocaleTimeString();
t = t.replace(/\u200E/g, '');
t = t.replace(/^([^\d]*\d{1,2}:\d{1,2}):\d{1,2}([^\d]*)$/, '$1$2');
var result = d + ' ' + t;
return result;
}
你可以在这里试试:http://jsfiddle.net/B5Zrx/
\u200E是我在一些IE版本上看到的格式化字符(它是unicode从左到右的标记)。
我假设如果格式化的时间包含类似“XX:XX:XX”的内容,那么它一定是带秒的时间,我删除了最后一部分,如果我没有找到这个模式,什么都没有改变。相当安全,但在一些奇怪的情况下,有可能会留下几秒钟。
我只是希望没有locale会改变格式化时间部分的顺序(例如,使它ss:mm:hh)。这个从左到右的标记让我有点紧张,这就是为什么我不删除从右到左的标记(\u202E) -我更喜欢在这种情况下不找到匹配,在这种情况下让时间格式化为秒。
使用locale:
var date = new Date();
date.toLocaleTimeString('fr-FR', {hour: '2-digit', minute: '2-digit'})
下面是一个函数,用注释解释:
function displayNiceTime(date){
// getHours returns the hours in local time zone from 0 to 23
var hours = date.getHours()
// getMinutes returns the minutes in local time zone from 0 to 59
var minutes = date.getMinutes()
var meridiem = " AM"
// convert to 12-hour time format
if (hours > 12) {
hours = hours - 12
meridiem = ' PM'
}
else if (hours === 0){
hours = 12
}
// minutes should always be two digits long
if (minutes < 10) {
minutes = "0" + minutes.toString()
}
return hours + ':' + minutes + meridiem
}
正如其他人所指出的那样,toLocaleTimeString()可以在不同的浏览器中以不同的方式实现,因此这种方式提供了更好的控制。
要了解更多关于Javascript Date对象的信息,可以参考https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date
你可以设置选项,在这个页面上你可以设置,去掉秒,像这样
var dateWithouthSecond = new Date();
dateWithouthSecond.toLocaleTimeString([], {hour: '2-digit', minute:'2-digit'});
支持Firefox、Chrome、IE9+和Opera。在你的web浏览器控制台试试。