我创建了一个显示帖子列表的WordPress站点。我创建了一个id为archive-tracks的div,然后使用一些jQuery在页面加载时将页面向下滚动到该div。
我希望这个功能只发生当我的分页链接之一被点击,在那一刻,它发生一旦有人进入网站的页面。
这是我的JS
jQuery(function(){
var target = "archive-tracks";
jQuery('html, body').animate({
scrollTop: jQuery('#'+target).offset().top
}, 1500,'swing');
return false;
});
是否有一种方法来停止这个动画,如果用户来自一个外部页面,但然后允许它当他们点击我的分页链接之一,通过我的帖子?
这是我的分页代码。
function dem_pagination( $pages = '', $range = 2 ) {
$showItems = ($range * 2)+1;
global $paged;
if (empty($paged)) $paged = 1;
if ($pages == '') {
global $wp_query;
$pages = $wp_query->max_num_pages;
if (!$pages) {
$pages = 1;
}
}
if ( $pages != 1 ) {
echo "<div class='pagination'>";
if ($paged > 2 && $paged > $range+1 && $showItems < $pages) {
echo "<a href='".get_pagenum_link(1). '#latest' . "'>«</a>";
}
if ($paged > 1 && $showitems < $pages) {
echo "<a href='".get_pagenum_link($paged - 1). '#latest' ."'>‹</a>";
}
for ($i=1; $i <= $pages; $i++) {
if (1 != $pages &&( !($i >= $paged+$range+1 || $i <= $paged-$range-1) || $pages <= $showitems )) {
echo ($paged == $i)? "<span class='current'>".$i."</span>":"<a href='".get_pagenum_link($i). '#latest' ."' class='inactive' >".$i."</a>";
}
}
if ($paged < $pages && $showitems < $pages) echo "<a href='".get_pagenum_link($paged + 1). '#latest' . "'>›</a>";
if ($paged < $pages-1 && $paged+$range-1 < $pages && $showitems < $pages) echo "<a href='".get_pagenum_link($pages). '#latest' ."'>»</a>";
echo "</div>'n";
}
}
不确定,但你可以这样做:
jQuery(function(){
if(window.location.hash){ //<------if hash values are location then only executes
var target = "archive-tracks";
jQuery('html, body').animate({
scrollTop: jQuery('#'+target).offset().top
}, 1500,'swing');
return false;
}
});