Вопрос

можно ли создать функцию jQuery, чтобы она получала текущую дату и время?Я просмотрел документацию, но пока ничего не нашел...

Это было полезно?

Решение

@nickf прав.Однако, если быть немного более точным:

// if you try to print it, it will return something like:
// Sat Mar 21 2009 20:13:07 GMT-0400 (Eastern Daylight Time)
// This time comes from the user's machine.
var myDate = new Date();

Итак, если вы хотите отобразить это как мм / дд / гггг, вы должны сделать это:

var displayDate = (myDate.getMonth()+1) + '/' + (myDate.getDate()) + '/' + myDate.getFullYear();

Посмотрите на полная ссылка объекта Date.К сожалению, распечатывать различные форматы далеко не так приятно, как с другими серверными языками.По этой причине там-являются-многие-функции доступен в дикой природе.

Другие советы

ДА, это возможно:

jQuery.now()

или просто

$.now()

смотрите Документацию jQuery для jQuery.now()

Для этого вам не нужен jquery, просто javascript.Например, вы можете создать таймер, используя это:

<body onload="clock();">

<script type="text/javascript">
function clock() {
   var now = new Date();
   var outStr = now.getHours()+':'+now.getMinutes()+':'+now.getSeconds();
   document.getElementById('clockDiv').innerHTML=outStr;
   setTimeout('clock()',1000);
}
clock();
</script>   

<div id="clockDiv"></div>

</body>

Вы можете ознакомиться с полной ссылкой здесь: http://www.hunlock.com/blogs/Javascript_Dates-The_Complete_Reference

Это простой javascript:

new Date()

Цифровые часы с JQuery

  <script type="text/javascript" src='http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js?ver=1.3.2'></script>
  <script type="text/javascript">
  $(document).ready(function() {
  function myDate(){
  var now = new Date();

  var outHour = now.getHours();
  if (outHour >12){newHour = outHour-12;outHour = newHour;}
  if(outHour<10){document.getElementById('HourDiv').innerHTML="0"+outHour;}
  else{document.getElementById('HourDiv').innerHTML=outHour;}

  var outMin = now.getMinutes();
  if(outMin<10){document.getElementById('MinutDiv').innerHTML="0"+outMin;}
  else{document.getElementById('MinutDiv').innerHTML=outMin;}

  var outSec = now.getSeconds();
  if(outSec<10){document.getElementById('SecDiv').innerHTML="0"+outSec;}
  else{document.getElementById('SecDiv').innerHTML=outSec;}

} myDate(); setInterval(function(){ myDate();}, 1000); }); </script> <style> body {font-family:"Comic Sans MS", cursive;} h1 {text-align:center;background: gray;color:#fff;padding:5px;padding-bottom:10px;} #Content {margin:0 auto;border:solid 1px gray;width:140px;display:table;background:gray;} #HourDiv, #MinutDiv, #SecDiv {float:left;color:#fff;width:40px;text-align:center;font-size:25px;} span {float:left;color:#fff;font-size:25px;} </style> <div id="clockDiv"></div> <h1>My jQery Clock</h1> <div id="Content"> <div id="HourDiv"></div><span>:</span><div id="MinutDiv"></div><span>:</span><div id="SecDiv"></div> </div>

это мой путь. :

    <script type="text/javascript">
$(document).ready(function() {
    setInterval(function(){currentTime("#idTimeField")}, 500);
});
function currentTime(field) {
    var now = new Date();
    now = now.getHours() + ':' + now.getMinutes() + ':' + now.getSeconds();
    $(field).val(now);
}

может быть, это и не самое лучшее, но делайте свою работу :)

Раздражающий Javascript date.getSeconds() et al не будет дополнять результат нулями 11:0:0 вместо того, чтобы 11:00:00.

Поэтому мне нравится использовать

date.toLocaleTimestring()

Который оказывает 11:00:00 AM.Просто будьте осторожны при использовании дополнительных опций, некоторые браузеры их не поддерживают (Safari).

Документация

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top