Часы с единым временем 
		
		
		
		
<script type="text/javascript">
 
function moscowTime() {
	var d = new Date();
	d.setHours( d.getHours() + 3, d.getMinutes() + d.getTimezoneOffset()  );
	return d.toTimeString().substring(0,8);
}
 
onload = function () {
  setInterval(function () {
    document.getElementById("txt").innerHTML = moscowTime();
  }, 100);
}
</script>
Хочу поставить часы на сайт, но чтобы у всех было единое время, использую код, но с ним такое не получается, как я понимаю препятствует new Date(); соотвественно если я на компе время поменяю, оно и там изменится, как этому можно препятствовать?  | 
	
		
 Серверное время передавай. 
	 | 
	
		
 а поподробнее можно? 
	 | 
	
		
 singmen, если требуется синхронизировать чеса клиентов по времени сервера, то отдавайте в JS смещение временной зоны сервера, на которую корректировать смещение клиента - часы у клиентов будут идти по времени сервера. Как передать это смещение, зависит от серверного языка. На РНР, это так: 
	
date("Z"); //в секундах со знаком
 | 
	
		
 сделал в таком виде: 
	
<span id="vern_time">
<?
echo date("H").":"; 
echo date("i").":";
echo date("s");
 ?></span>
 <script>
setInterval(function () {$('#tm').load('/do/time.php #vern_time');}, 100);
</script>
<span id="tm"></span>
но получается таким образом я ддосю сервер, бывает за 6-12 секунд за раз прыгает  | 
	
		
 Не так. Смещение временной зоны на клиенте возвращается в минутах, на сервере, если РНР, в секундах. 
	Если у вас РНР, отдавая страницу клиенту дописывайте в конце нее (перед закрывающим тегом body): 
<script>var sZone = <?=date("Z") * 1000?></script>
Сервер и клиент возвращают смещение часового пояса с разными знаками по разную сторону от Гринвича. Поэтому плюсуя к смещению клиента смещение сервера получаем смещение на которое нужно скорректировать часы клиента, например: var Zone = new Date().getTimezoneOffset() * 60 * 1000 + sZone; var watch = new Date((new Date).getTime() + Zone); //время которое устанавливается в часах  | 
	
		
 Цитата: 
	
 Можно взять и таймштамп серверного времени, корректировать его каждую секунду, открывать дату по этому времени. singmen, 
<html>
<head>
</head>
<body>
<div id="times"></div>
<!--Contents-->
<script>//var zO = new Date().getTimezoneOffset() * 60 * 1000 + <?=date("Z") * 1000?>; //это должно быть реально в скрипте
var zO = new Date().getTimezoneOffset() * 60 * 1000 + 10800000; //а это для действующего примера, по Москве, удалить из реального скрипта
function watch() {
    var d = new Date((new Date).getTime() + zO), 
        t = d.getMinutes(),
        locale = 'ru-RU', 
        options = {year: 'numeric', month: 'long', day: 'numeric'};
    
    return {
        dY : d.getFullYear(), 
        dM : d.getMonth() + 1, 
        dD : d.getDate(), 
        sD : d.toLocaleDateString(locale, options), //локальное представление даты, поддержка locale и options: FF 29, IE 11, Opera 15, в Safari нет поддержки русской локали 
        tH : d.getHours(), 
        tM : t < 10 ? "0"+t : t, 
        tS : d.getSeconds()
    } 
}
function outTime() {
   var t = watch(); //объект значений текущего времени
   //выводим во что-то время
   document.getElementById('times').innerHTML = '<pre>' + t.sD + ' ' + t.tH + (t.tS & 1 ? ':' : ' ') + t.tM + '</pre>';
   setTimeout(outTime, 1000);   
}
outTime();
</script>
</body>
</html>
 | 
	
		
 Цитата: 
	
  | 
	
		
 Цитата: 
	
 Если же нужна проверка чего-то от "накрутили", то нужны не просто часы на клиенте, а запрашивать у клиента его часовой пояс и делать проверку на сервере, ибо подкрутить можно что угодно, хоть используя Date, хоть математику с цифрами, и уж если на то пошло, то просто слать сервером без всякого клиента лабуду. Ну это же не серьезно. )  | 
	
		
 Цитата: 
	
  | 
| Часовой пояс GMT +3, время: 08:05. |