Я устраиваю свой блог с помощью социальных счетчиков на домашней странице. Блог показывает 10 сообщений и загружает больше с бесконечным прокруткой.
Учитывая, что он должен делать 3 запроса за сообщение, а также должен отображать 10 сообщений - это означает, что 30 запросов должны пройти до отображения страницы.
Используя get_transient/set_transient, кажется, что загрузка страницы происходит мгновенно, но после каждого часа у 1 человека будут плохие времена загрузки - просто интересно, могу ли я сделать это быстрее, проверив с помощью jQuery, если переменные изменились или нет (если они есть, то сделать запрос на загрузку после загрузки страницы).
Я вообще не знаю jQuery и буду признателен за помощь в этом.
function getShares($url){
$fbcount = get_transient('share_count');
if ($fbcount !== false) return $fbcount;
$fbcount = 0;
$fql = "SELECT share_count FROM link_stat WHERE url = '".$url."'";
$apifql = "https://api.facebook.com/method/fql.query?format=json&query=".urlencode( $fql );
$json = file_get_contents( $apifql );
$data = json_decode($json);
$fbcount = $data[0]->share_count;
set_transient('share_count', $fbcount, 60*60);
return $fbcount;
}
function getPlus1($url) {
$gpcount = get_transient('plusone_count');
if ($gpcount !== false) return $gpcount;
$gpcount = 0;
$html = file_get_contents( "https://plusone.google.com/_/+1/fastbutton?url=".urlencode($url));
$doc = new DOMDocument(); $doc->loadHTML($html);
$counter=$doc->getElementById('aggregateCount');
$gpcount = $counter->nodeValue;
set_transient('plusone_count', $gpcount, 60*60);
return $gpcount;
}
function getTweets($url){
$tweetcount = get_transient('tweet_count');
if ($tweetcount !== false) return $tweetcount;
$tweetcount = 0;
$json = file_get_contents( "http://urls.api.twitter.com/1/urls/count.json?url=".$url );
$ajsn = json_decode($json, true);
$tweetcount = $ajsn['count'];
set_transient('tweet_count', $tweetcount, 60*60);
return $tweetcount;
}
Сохраняйте результаты в базе данных, и если результаты старше часа, снова загрузите их.
(И, конечно, снова добавьте его в базу данных с новыми данными).
Для этого вам даже не нужен jQuery.