我有一个页面加载了一堆PHP块,需要花费很多时间。 它们最初是隐藏的,直到用户使用jQuery slideToggle弹出它们。
有没有办法让HTML首先加载,然后加载PHP?
以下是相关摘录:
<script type="text/javascript">
jQuery(function($){
$('a.toggler').click(function(){
$(this).next().slideToggle('slow');
return false; //ensures no anchor jump
});
});
</script>
...
<div class='gallerysection'>
<a href='#' class='toggler'>Logos & Type</a>
<div class='toggle'><?php $album='1755641';include('VimeoAlbumSimple.php'); ?></div>
<a href='#' class='toggler'>Infographics & UIs</a>
<div class='toggle'><?php $album='1755635';include('VimeoAlbumSimple.php'); ?></div>
</div>
include('VimeoAlbumSimple.php')
从vimeo加载一堆图像和链接,每次调用都需要几秒钟才能加载。页面上有10个以上。
这是VimeoAlbumSimple.php
:
require_once('/home/dzg/zinclabs.com/assets/vimeolib.php');
$vimeo = new phpVimeo('807d405c3bf97d7c20060dabce349b6a', '9cc9d85a3b91b1a7');
$vimeo->setToken('274e2c915371a405ac1ec1cd7c3a72a5','3fe84c74bd6b4a9f736a41cb5709a76ec222686c');
$result = $vimeo->call('vimeo.albums.getVideos', array('album_id' => $album,full_response => '1'));
$videos = $result->videos->video;
echo '<div class="gallery">';
foreach ($videos as $video) {echo '
<div class="item">
<a href="http://player.vimeo.com/video/'.$video->id
.'?autoplay=1&title=0&byline=0&portrait=0&wmode=transparent" title="'
.$video->title.'" class="zoombox zgallery1">'
.'<img src="posters/'.$video->id.'.jpg" />'
.'<span class="text">
<span class="title">'.$video->title.'</span>'
.'<span class="duration">'.ltrim(gmdate("i:s", $video->duration),"0").'</span>'
.'<span class="description">'.nl2br($video->description).'</span>'
.'<div class="clear"></div>
</span>
</a>
</div>';
}
echo '</div>';
答案 0 :(得分:4)
在呈现HTML之后,您无法延迟PHP处理,因为PHP首先会生成HTML。
您可以做的是在加载“主”布局后使用AJAX加载网页的各个部分。例如:
<div class='gallerysection'>
<a href='#' class='toggler'>Logos & Type</a>
<div class='toggle' data-url="VimeoAlbumSimple.php?album=1755641"></div>
<a href='#' class='toggler'>Infographics & UIs</a>
<div class='toggle' data-url="VimeoAlbumSimple.php?album=1755635"></div>
</div>
jQuery(function($){
$('.gallerysection .toggle').each(function(){
var $this = $(this);
$this.load($this.data("url"));
});
});
在这里,我使用HTML5 data attribute将幻灯片中的每个div与将呈现其内容的URL相关联。当DOM准备就绪时,jQuery使用.data
获取此URL,并使用.load
发出AJAX请求以获取HTML并将其插入(最初为空)占位符。