[ Поиск ] - [ Пользователи ] - [ Календарь ]
Полная Версия: Счетчик в реальном времени
VladokZzz
Привет! У меня есть счетчик присутствия на сайте. Высвечивается при попадании на страницу переменной $count. Мне нужно, что бы не приходилось нажимать F5 счетчик в реальном времени сам обновлялся и менялся на странице без обновления самой страницы. Как это реализовать?
Заранее спасибо!



Спустя 2 дня, 2 часа, 52 минуты, 20 секунд (15.03.2010 - 15:57) vinny_sk написал(а):
помещаешь данный счетчик в отдельный div, который будешь обновлять с помощью ajax
тебе надо написать js функцию, которая будет через определенное время, например, раз в минуту вызывать функцию работы через ajax, а та уже будет обновлять счетчик...
но это уже вопрос не php это js...

Спустя 2 часа, 49 минут, 26 секунд (15.03.2010 - 18:47) Игорь_Vasinsky написал(а):
зачем на прямую JS, когда можно эту переменную подгружать через include в отделной странице, а там уже ра JS обновление страницы ? разве нет ?

Спустя 56 секунд (15.03.2010 - 18:48) Игорь_Vasinsky написал(а):
а лучше через <iframe> - 100 % работает, я так тикающие часики делал

Спустя 34 минуты, 21 секунда (15.03.2010 - 19:22) phz написал(а):
Использ. фрейм для игрушек нерационально.

Спустя 1 минута, 46 секунд (15.03.2010 - 19:24) Игорь_Vasinsky написал(а):
Цитата
Использ. фрейм для игрушек нерационально

для счётчика онлайн

Спустя 17 часов, 4 минуты, 21 секунда (16.03.2010 - 12:28) vinny_sk написал(а):
с js могут возникнуть проблемы только когда он по факту отключен... а насчет iframe согласен его здесь вполне логично использовать... это на мой взгляд тот случай когда подходов масса и какой выбрать вопрос не особо принципиальный...
и изначально конечно отображаешь, а потом уже обновляешь...

Спустя 4 часа, 19 минут, 48 секунд (16.03.2010 - 16:48) VladokZzz написал(а):
Парни, то что это реализуемо я знаю smile.gif Пример можно реализации?
У меня идет общий php состоящий из инклудов... один из инклудов так же php и в нем есть эта переменная которую я хочу в реальном времени обновлять на странице у посетителей.

Спустя 35 минут, 49 секунд (16.03.2010 - 17:24) Игорь_Vasinsky написал(а):
Твоя страница:

<?php 
include "header.php";
// если счётчик тута то:
echo "
<iframe src='count.php'></iframe>
// width b height - придётся тыком подсчитать
"
;
include "content.php";
include "footer.php";
?>


как релоад на странице через 1 ctr делать тож написать ?

Спустя 50 минут, 53 секунды (16.03.2010 - 18:15) VladokZzz написал(а):
Т.е. iframe это типа фреймсета и инклуда но в режиме онлайн?
релоад знаю... скрипт + запись в body или есть одной функцией?

Спустя 2 минуты, 54 секунды (16.03.2010 - 18:18) Игорь_Vasinsky написал(а):
ну вот. правильно, а iframe - здесь тоже самое что и include - тока независимо от всей страницы, т.к. include вставляет содержимое не посредственно на страницу, а iframe - вставляется как отдельная страница

Спустя 17 минут, 5 секунд (16.03.2010 - 18:35) VladokZzz написал(а):
Понял спасибо! Только вот мой релоад не корректно работает:
1 файл
<?php
echo "<iframe src='2.php'></iframe>";
?>
2 файл
<script>
function reload()
{top.location.href="2.php"}
</script>
<link href="style.css" rel="stylesheet" type="text/css">
<body onload="setTimeout('reload()',2500)">
//PHP код
Открываем 1.php и видим этот фрейм из 2.php а потом идет обновление и 1 замещается вторым... тобишь обновляется не iframe а вся страница и открывается 2.php

Спустя 8 минут, 35 секунд (16.03.2010 - 18:43) Игорь_Vasinsky написал(а):
в неадер вставь

<meta http-equiv="refresh" content="10; url= http://твой сайт/2.php" />

Спустя 1 минута, 16 секунд (16.03.2010 - 18:45) Игорь_Vasinsky написал(а):
Цитата
<script>
function reload()
{top.location.href="2.php"}
</script>


убери вообще, и body очисти от js

Спустя 13 минут, 50 секунд (16.03.2010 - 18:58) VladokZzz написал(а):
убрал весь хтмл код он там лишний... оставил только мету
спасибо! все теперь отлично wink.gif респект

Спустя 22 минуты, 2 секунды (16.03.2010 - 19:20) VladokZzz написал(а):
Интересно а как на сайте vkontakte.ru сделано... там в режиме онлайн меняется кол-во зарегистрированных... на главной и без рефреша

Спустя 2 минуты, 39 секунд (16.03.2010 - 19:23) Игорь_Vasinsky написал(а):
возможно AJAX

Спустя 1 час, 29 секунд (16.03.2010 - 20:24) qpayct написал(а):
или просто скрипт наипок

Спустя 20 минут, 53 секунды (16.03.2010 - 20:44) VladokZzz написал(а):
Вот бы мне без рефреша... А как затестить ajax?

Спустя 3 минуты, 7 секунд (16.03.2010 - 20:48) qpayct написал(а):
тут полно готовых решений - в поиск!

Спустя 1 час, 36 минут, 45 секунд (16.03.2010 - 22:24) VladokZzz написал(а):
Клевый совет! Безгранично благодарен... и все же я выслушаю других форумчан

Спустя 21 час, 27 минут, 13 секунд (17.03.2010 - 19:52) VladokZzz написал(а):
Игорь, iframe в IE8 не работает... не обновляется счетчик... А в опере нормально sad.gif

Спустя 9 минут, 6 секунд (17.03.2010 - 20:01) phpdreamer написал(а):
Цитата (Игорь_Vasinsky @ 16.03.2010 - 16:23)
возможно AJAX

разумеется... других вариантов и нет.

вот библиотека SAJAX
<?php	
if (!isset($SAJAX_INCLUDED)) {

/*
* GLOBALS AND DEFAULTS
*
*/

$GLOBALS['sajax_version'] = '0.12';
$GLOBALS['sajax_debug_mode'] = 0;
$GLOBALS['sajax_export_list'] = array();
$GLOBALS['sajax_request_type'] = 'GET';
$GLOBALS['sajax_remote_uri'] = '';
$GLOBALS['sajax_failure_redirect'] = '';

/*
* CODE
*
*/

//
// Initialize the Sajax library.
//

function sajax_init() {
}


//
// Helper function to return the script's own URI.
//

function sajax_get_my_uri() {
return $_SERVER["REQUEST_URI"];
}
$sajax_remote_uri = sajax_get_my_uri();

//
// Helper function to return an eval()-usable representation
// of an object in JavaScript.
//

function sajax_get_js_repr($value) {
$type = gettype($value);

if ($type == "boolean") {
return ($value) ? "Boolean(true)" : "Boolean(false)";
}
elseif ($type == "integer") {
return "parseInt($value)";
}
elseif ($type == "double") {
return "parseFloat($value)";
}
elseif ($type == "array" || $type == "object" ) {
//
// XXX Arrays with non-numeric indices are not
// permitted according to ECMAScript, yet everyone
// uses them.. We'll use an object.
//

$s = "{ ";
if ($type == "object") {
$value = get_object_vars($value);
}
foreach ($value as $k=>$v) {
$esc_key = sajax_esc($k);
if (is_numeric($k))
$s .= "$k: " . sajax_get_js_repr($v) . ", ";
else
$s .= "\"$esc_key\": " . sajax_get_js_repr($v) . ", ";
}
if (count($value))
$s = substr($s, 0, -2);
return $s . " }";
}
else {
$esc_val = sajax_esc($value);
$s = "'$esc_val'";
return $s;
}
}


function sajax_handle_client_request() {
global $sajax_export_list;

$mode = "";

if (! empty($_GET["rs"]))
$mode = "get";

if (!empty($_POST["rs"]))
$mode = "post";

if (empty($mode))
return;

$target = "";

if ($mode == "get") {
// Bust cache in the head
header ("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); // Date in the past
header ("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
// always modified
header ("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1
header ("Pragma: no-cache"); // HTTP/1.0
$func_name = $_GET["rs"];
if (! empty($_GET["rsargs"]))
$args = $_GET["rsargs"];
else
$args = array();
}
else {
$func_name = $_POST["rs"];
if (! empty($_POST["rsargs"]))
$args = $_POST["rsargs"];
else
$args = array();
}

if (! in_array($func_name, $sajax_export_list))
echo "-:$func_name not callable";
else {
echo "+:";
$result = call_user_func_array($func_name, $args);
echo "var res = " . trim(sajax_get_js_repr($result)) . "; res;";
}
exit;
}

function sajax_get_common_js() {
global $sajax_debug_mode;
global $sajax_request_type;
global $sajax_remote_uri;
global $sajax_failure_redirect;

$t = strtoupper($sajax_request_type);
if ($t != "" && $t != "GET" && $t != "POST")
return "// Invalid type: $t.. \n\n";

ob_start();
?>

// remote scripting library
// © copyright 2005 modernmethod, inc

var sajax_debug_mode = <?php echo $sajax_debug_mode ? "true" : "false"; ?>;
var sajax_request_type = "<?php echo $t; ?>";
var sajax_target_id = "";
var sajax_failure_redirect = "<?php echo $sajax_failure_redirect; ?>";

function sajax_debug(text) {
if (sajax_debug_mode)
alert(text);
}

function sajax_init_object() {
sajax_debug("sajax_init_object() called..")

var A;

var msxmlhttp = new Array(
'Msxml2.XMLHTTP.5.0',
'Msxml2.XMLHTTP.4.0',
'Msxml2.XMLHTTP.3.0',
'Msxml2.XMLHTTP',
'Microsoft.XMLHTTP');
for (var i = 0; i < msxmlhttp.length; i++) {
try {
A = new ActiveXObject(msxmlhttp[i]);
} catch (e) {
A = null;
}
}


if(!A && typeof XMLHttpRequest != "undefined")
A = new XMLHttpRequest();
if (!A)
sajax_debug("Could not create connection object.");
return A;
}

var sajax_requests = new Array();

function sajax_cancel() {
for (var i = 0; i < sajax_requests.length; i++)
sajax_requests[i].abort();
}

function sajax_do_call(func_name, args) {
var i, x, n;
var uri;
var post_data;
var target_id;

sajax_debug("in sajax_do_call().." + sajax_request_type + "/" + sajax_target_id);
target_id = sajax_target_id;
if (typeof(sajax_request_type) == "undefined" || sajax_request_type == "")
sajax_request_type = "GET";

uri = "<?php echo $sajax_remote_uri; ?>";
if (sajax_request_type == "GET") {

if (uri.indexOf("?") == -1)
uri += "?rs=" + escape(func_name);
else
uri += "&rs=" + escape(func_name);
uri += "&rst=" + escape(sajax_target_id);
uri += "&rsrnd=" + new Date().getTime();

for (i = 0; i < args.length-1; i++)
uri += "&rsargs[]=" + escape(args[i]);

post_data = null;
}
else if (sajax_request_type == "POST") {
post_data = "rs=" + escape(func_name);
post_data += "&rst=" + escape(sajax_target_id);
post_data += "&rsrnd=" + new Date().getTime();

for (i = 0; i < args.length-1; i++)
post_data = post_data + "&rsargs[]=" + escape(args[i]);
}
else {
alert("Illegal request type: " + sajax_request_type);
}

x = sajax_init_object();
if (x == null) {
if (sajax_failure_redirect != "") {
location.href = sajax_failure_redirect;
return false;
} else {
sajax_debug("NULL sajax object for user agent:\n" + navigator.userAgent);
return false;
}
}
else {
x.open(sajax_request_type, uri, true);
// window.open(uri);

sajax_requests[sajax_requests.length] = x;

if (sajax_request_type == "POST") {
x.setRequestHeader("Method", "POST " + uri + " HTTP/1.1");
x.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
}

x.onreadystatechange = function() {
if (x.readyState != 4)
return;

sajax_debug("received " + x.responseText);

var status;
var data;
var txt = x.responseText.replace(/^\s*|\s*$/g,"");
status = txt.charAt(0);
data = txt.substring(2);

if (status == "") {
// let's just assume this is a pre-response bailout and let it slide for now
} else if (status == "-")
alert("Error: " + data);
else {
if (target_id != "")
document.getElementById(target_id).innerHTML = eval(data);
else {
try {
var callback;
var extra_data = false;
if (typeof args[args.length-1] == "object") {
callback = args[args.length-1].callback;
extra_data = args[args.length-1].extra_data;
} else {
callback = args[args.length-1];
}
callback(eval(data), extra_data);
} catch (e) {
sajax_debug("Caught error " + e + ": Could not eval " + data );
}
}
}
}
}


sajax_debug(func_name + " uri = " + uri + "/post = " + post_data);
x.send(post_data);
sajax_debug(func_name + " waiting..");
delete x;
return true;
}

<?php
$html = ob_get_contents();
ob_end_clean();
return $html;
}

function sajax_show_common_js() {
echo sajax_get_common_js();
}

// javascript escape a value
function sajax_esc($val)
{
$val = str_replace("\\", "\\\\", $val);
$val = str_replace("\r", "\\r", $val);
$val = str_replace("\n", "\\n", $val);
$val = str_replace("'", "\\'", $val);
return str_replace('"', '\\"', $val);
}

function sajax_get_one_stub($func_name) {
ob_start();
?>

// wrapper for <?php echo $func_name; ?>

function x_<?php echo $func_name; ?>() {
sajax_do_call("<?php echo $func_name; ?>",
x_<?php echo $func_name; ?>.arguments);
}

<?php
$html = ob_get_contents();
ob_end_clean();
return $html;
}

function sajax_show_one_stub($func_name) {
echo sajax_get_one_stub($func_name);
}

function sajax_export() {
global $sajax_export_list;

$n = func_num_args();
for ($i = 0; $i < $n; $i++) {
$sajax_export_list[] = func_get_arg($i);
}
}


$sajax_js_has_been_shown = 0;
function sajax_get_javascript()
{
global $sajax_js_has_been_shown;
global $sajax_export_list;

$html = "";
if (! $sajax_js_has_been_shown) {
$html .= sajax_get_common_js();
$sajax_js_has_been_shown = 1;
}
foreach ($sajax_export_list as $func) {
$html .= sajax_get_one_stub($func);
}
return $html;
}

function sajax_show_javascript()
{
echo sajax_get_javascript();
}


$SAJAX_INCLUDED = 1;
}
?>

а
вот пример отображения даты и времени (и обновления)

<?
require("Sajax.php");

// Leonardo Lorieri
// My first SAJAX implementention, few lines of inspiration
// A good way to understand SAJAX programming
//
// Work Flow:
// 1- starting by the <body onload="get_date()">
// 2- loading the server's date from the php function,
// calling the javascript function to show it.
// 3- scheduling another load to the next second
//
// Disclaimer: Hey! I dont speak english
// Under (put your choice here) license


function show_now() {
//return server date
return date("l dS of F Y h:i:s A");
}

//starting SAJAX stuff
$sajax_request_type = "GET";
sajax_init();
sajax_export("show_now");
sajax_handle_client_request();
?>
<html>
<
head>
<
title>Show Server's Date</title>
<script>
<?
sajax_show_javascript();
?>
function show_me(date_server) {
document.getElementById("date_div").innerHTML = date_server;
}

function get_date() {

//put the return of php'
s show_now func
//to the javascript show_me func as a parameter
x_show_now(show_me);

//do it every 1 second
setTimeout("get_date()", 1000);
}
</script>

</
head>
<
body onload="get_date();">
Server date: <div id="date_div">(loading...)</div>
</
body>
</
html>

Спустя 50 минут, 41 секунда (17.03.2010 - 20:51) VladokZzz написал(а):
Большое спасибо! Сейчас потестирую...

Спустя 5 дней, 22 часа, 13 минут, 45 секунд (23.03.2010 - 19:05) VladokZzz написал(а):
А как будет выглядеть этот вариант на моем примере? У меня есть в PHP переменная $count в которую подставляется значение, к примеру присутствующих на сайте. Кол-во людей меняется и я хочу что бы и эта переменная на странице выдавал актуальное значение.

Спустя 1 день, 1 час, 25 минут, 58 секунд (24.03.2010 - 20:31) VladokZzz написал(а):
нид хелп

Спустя 17 дней, 21 час, 25 минут, 40 секунд (12.04.2010 - 16:57) VladokZzz написал(а):
Ничего не выходит... Игорь, прошу помощи!

Спустя 22 дня, 20 часов, 28 минут, 39 секунд (5.05.2010 - 13:25) VladokZzz написал(а):
ап!

Спустя 1 месяц, 22 дня, 21 час, 10 минут, 28 секунд (28.06.2010 - 10:36) VladokZzz написал(а):
Все еще нужен хелп
Быстрый ответ:

 Графические смайлики |  Показывать подпись
Здесь расположена полная версия этой страницы.
Invision Power Board © 2001-2025 Invision Power Services, Inc.