Indstil effekten af ​​at klikke på raketikonet jquery scroll tilbage til den øverste JS-kode

del hvordanhood.discountImplementer effekten af ​​at "klikke på raketten for at vende tilbage til toppen" i temaet.

  • Hvis du er en WordPress-whiz, ved du, hvordan du porterer det til et WordPress-tema.
  • Denne artikel passer ogsåbygge en hjemmesidenybegynder.

Rocket Ascent Tilbage til toppen Billede

Klik på raketstigningen for at vende tilbage til det øverste billede 1

Download ovenstående billede på forhånd, det anbefales at lægge det i billedmappen under temabiblioteket.

Trin 1: Indlæs jQuery-biblioteksfilerne

  • Indlæs jQuery-biblioteksfilen, hvis WordPress-temaet allerede er indlæst, kan du ignorere dette trin;

WordPress introducerer 3. parts jQuery-bibliotek, tjek venligst denne vejledning ▼

Trin 2: Tilføj kode til footer.php-fil

Tilføj følgende kode til den tilsvarende placering i temafoden.php ▼

<div class="one"></div>
<div id="backtotop" style="display:none;"></div>

Trin 3: Tilføj kode til CSS-fil

Tilføj følgende CSS-kode til temaets style.css-fil ▼

.one {width:100%;height:3000px;}
#backtotop {background:url(images/rocket_up.png) 0px 0px no-repeat;position:fixed;bottom:0px;right:10px;width:149px;height:260px;cursor: pointer;z-index:1000;}

Trin 4: Tilføj tilbage til toppen JS-kode

For den følgende js-kode kan du oprette en anden js-fil;

eller flet den ind i den relevante js-fil af et eksisterende tema (anbefales);

eller du kan pakke det ind i footer.php Medium ▼

var scrollTT = {
tTSpeed : 800, // 滚动到顶部的时间
startFlyTime : 1000, // 火箭起飞的时间
restartTime : 1200, // 重置火箭位置的时间
flySpeed : 50, // 火箭向上飞行的速度
obj : $("#backtotop"), // 回到顶部的dom
flyTemp : '', // 一个setInterval的临时变量
/**
* 
* 初始化 scrollTT 函数
* 主要是像对象添加事件
*
*/
init : function( obj, tTSpeed, startFlyTime, restartTime, flySpeed ) {
scrollTT.tTSpeed = scrollTT.tTSpeed || tTSpeed;
scrollTT.startFlyTIme = scrollTT.startFlyTIme || startFlyTime;
scrollTT.restartTime = scrollTT.restartTime || restartTime;
scrollTT.flySpeed = scrollTT.flySpeed || flySpeed;
scrollTT.obj = scrollTT.obj || obj;

// 向window 绑定scroll 事件
scrollTT.onScroll();


scrollTT.obj.click(function(){
// 关闭默认的scroll事件
$(window).off("scroll");
// 页面向上滚动
$('html,body').animate({scrollTop: '0px'}, this.tTSpeed);
// 火箭向上飞行
scrollTT.objFly();
// 火箭的喷气效果
scrollTT.blow();

});

// 鼠标在火箭上的效果
scrollTT.obj.mouseenter(function() {
$(this).css('background-position', '-149px 0px');
});
// 鼠标移开的效果
scrollTT.obj.mouseleave(function() {
$(this).css('background-position', '0px 0px');
});

}, 
/*
* 向window 绑定scroll 事件
*
*/
onScroll : function() {
$(window).on('scroll', function() {
if ($(window).scrollTop()>500){
scrollTT.obj.fadeIn(500);
}else{
scrollTT.obj.fadeOut(1500);
}
});
},
/**
* dom对象向上飞行
*
*/
objFly : function() {
var fly = setTimeout(function(){
scrollTT.obj.animate({top: '-500px'} ,'normal', 'swing');
scrollTT.resetFly();
clearTimeout(fly);
clearInterval(scrollTT.flyTemp);
}, scrollTT.startFlyTime);
},
/**
* dom 对象飞行完毕回到原来的位置
*
*/
resetFly : function() {
var fly2 = setTimeout(function() {
scrollTT.obj.hide();
scrollTT.obj.css("top", 'auto');
scrollTT.obj.css("background-position", '0px 0px');
scrollTT.onScroll();
clearTimeout(fly2);
},scrollTT.restartTime);
},
/**
* dom 对象的喷气效果
*
*/
blow : function() {
var topPosiiton = -149;
scrollTT.flyTemp = setInterval(function() {
topPosiiton += -149;
if(topPosiiton < -743) {
topPosiiton = -149
}
scrollTT.obj.css('background-position', topPosiiton + 'px 0px');
}, this.flySpeed);
}
};

scrollTT.init();

 

发表 评论

Din e-mailadresse vil ikke blive offentliggjort. 必填 项 已 用 * 标注

Rul til top