Javascript-форум (https://javascript.ru/forum/)
-   Элементы интерфейса (https://javascript.ru/forum/dom-window/)
-   -   Как открывать и закрывать ссылку по таймеру с отсчетом времени до и после? (https://javascript.ru/forum/dom-window/76082-kak-otkryvat-i-zakryvat-ssylku-po-tajjmeru-s-otschetom-vremeni-do-i-posle.html)

bridun 03.12.2018 11:07

Как открывать и закрывать ссылку по таймеру с отсчетом времени до и после?
 
Вложений: 1
Подскажите как прикрутить к php javascript . Есть код и он работает, как к нему прикрутить таймер времени javascript такого авто обновления чтоб обновлять время и и сделать активную/не активную ссылку

внизу даю скрин увидел винтернете это такая крутилка видео
Код:

time_table.dat такого вида

1|text|link|04|12|2018|10:00:00|9:55:00|10:30:00|
2|text|link|04|12|2018|16:00:00|16:55:00|17:30:00|
3|text|link|04|12|2018|19:00:00|18:55:00|19:30:00|

date_default_timezone_set('Europe/Kiev');//timzone


    $data =  file("time_table.dat");

  foreach($data as $rows) {

    $elem = explode("|", $rows);
    if (!strripos($rows, "|")) continue;
///////////////////////////////////////////////////////////////
$met = $elem[3].'-'.$elem[4].'-'.$elem[5].' '.$elem[7];
$metTS = strtotime($met);
//echo strftime("%d-%m-%Y %H:%M:%S", $metTS).'  ';
//echo strftime("%d-%m-%Y %H:%M:%S");
 $sub = $metTS - time();


$sub = abs($sub);
$days = (int)($sub / (24*60*60));
$hours = (int)(($sub - $days * 24 * 60 * 60) / (60*60));
$min = (int)(($sub - $days * 24 * 60 *60 - $hours * 60 * 60) / 60);
$sec = $sub - $days * 24 * 60 *60 - $hours * 60 * 60 - $min * 60;
/////////////////////////////////////////////////////////////////////
      $start = $elem[7];
      $end = $elem[8];
      $enter = '';
    $cur_time = strftime('%H:%M:%S', time()); 
       
    if ($cur_time > $start && $cur_time < $end){
    $enter = '<a href="'.$elem[2].'" target="_blank">Активная</a></div>';
    }else{
    $enter = '<a href="#">Неактивная</a>';
    }
///////////////////////////////////////////////////////////////////
   
echo'<table border="1" align="center" cellpadding="0" cellspacing="0" width="300">

  <tr>
    <td valign="top" align="center"  width="150">
        '.$elem[3].'/'.$elem[4].'/'.$elem[5].'-'.$elem[6].'<br>
    '.$elem[1].'
    </td>
    <td valign="top" align="center"  width="150">       
      '. $hours.':'. $min.':'. $sec.'
        <br>'. $enter .'
    </td>
  </tr>
</table>';
  }


laimas 03.12.2018 11:58

Цитата:

Сообщение от bridun
как прикрутить к php js

Никак, РНР на сервере, JS на клиенте.

bridun 03.12.2018 16:42

ну хорошо а какое есть или возможное решение втаком случае

laimas 03.12.2018 17:06

Решение чего? Что-то показать/скрыть по таймеру на клиенте, это javascript, причем тут РНР? Пишите что нужно скрывать/показывать и т.д., тогда и решение предложат.

bridun 03.12.2018 22:32

я для примера показал что я сделал и спросил что можно сделать в такомм случае

bridun 03.12.2018 22:33

я думаю что я достаточно понятно спросил и php здесь не причем

laimas 04.12.2018 01:40

Цитата:

Сообщение от bridun
я думаю что я достаточно понятно спросил

Нифига не понятно чего там скрывать. А понятно из РНР кода, что по условиям определяемых временем будет вывод в браузер той или иной ссылки. Вот только если говорить о РНР, то это большая глупость сравнивать не временные метки (time()), а их строковые представления. Сравнение строк может закончится совсем и не ожидаемым результатом.

Если это нужно сделать на клиенте, то данные для условия и ссылки, нужно передать клиенту, он тоже сделает, но это ни к чему.

А если речь о таймере, то не надо приводить тут РНР код, это ваши проблемы, а приводить чистый html, и поставить вопрос - как в нем что-то, показать/скрыть по таймеру, условию и т.п.

Если такого кода и пояснения не будет, то и вряд ли вам кто-то предложит решение.

bridun 11.12.2018 16:41

получилось переделать сылка открывается в нужное время а типерь ее нужно спрятать по истичению времени

<html>
<head>
<title> Таймер обратного отсчета </title>

</head>
<body >

<?php
//error_reporting (0);
ini_set('error_reporting', E_ALL);
ini_set('display_errors', 1);
ini_set('display_startup_errors', 1);
	//date_default_timezone_set('Europe/Kiev');//timzone
	
/**  time_table.dat
1|text|link|12|10|2018|10:00:00|09:55:00|10:30:00|  
2|text|link|12|10|2018|21:00:00|20:55:00|21:30:00|  
3|text|link|12|10|2018|22:00:00|21:55:00|22:30:00| 
*/
	date_default_timezone_set('Europe/Kiev');//timzone


    $data =  file("time_table.dat");

	foreach($data as $rows) {

		$elem = explode("|", $rows);
		if (!strripos($rows, "|")) continue;
		 
echo'<table border="1" align="center" cellpadding="0" cellspacing="0" width="300">

	<tr>
		<td valign="top" align="center"  width="150">
        '.$elem[3].'/'.$elem[4].'/'.$elem[5].'-'.$elem[6].'<br>
		'.$elem[1].'
		</td>
		<td valign="top" align="center"  width="150">
<script type="text/javascript">

/////////////////////////
timedown("'.$elem[3].','.$elem[4].','.$elem[5].','.$elem[7].'","link_'.$elem[0].'");
//var countDownDate = new Date("<?=$elem[3].','.$elem[4].','.$elem[5].','.$elem[8];?>").getTime();// до закрытия ссылки 
function timedown(ti,id){

var countDownDate = new Date(ti).getTime();

var x = setInterval(function() {

    var now = new Date().getTime();
    
    var distance = countDownDate - now;
    
    var days = Math.floor(distance / (1000 * 60 * 60 * 24));
    var hours = Math.floor((distance % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
    var minutes = Math.floor((distance % (1000 * 60 * 60)) / (1000 * 60));
    var seconds = Math.floor((distance % (1000 * 60)) / 1000);
    
document.getElementById(id).innerHTML = "до входа<br>"+(days!=0 ? days + ":" : "") + (hours!= 0 ? hours + ":" : "") + (minutes != 0 ? minutes + ":" : "") + seconds + "<br><a href=\"#\">Неактивная</a>";

    if (distance < 0) {
        clearInterval(x);
        document.getElementById("link_'.$elem[0].'").innerHTML = "<a href=\"'.$elem[2].'\">Активная</a>";
		//window.location = "final.php" // по окончанию времени перейти на другу страницу

    }
}, 1000);
}

/**  помогите прикрутить таймер до закрытия ссылки и спрятать ссылку обратно*/

</script>		
		
<span id="link_'.$elem[0].'"></span>

		
		</td>
	</tr>
</table>';
	}

?>


</body>
</html>


Часовой пояс GMT +3, время: 22:45.