用原生JavaScript做个简单的回到顶部

很多网页在下方都会放置一个“返回顶部”按钮,尤其是页面底部没有导航的网页,这样可以帮助访客重新找到导航或者重温一遍广告(想得真美)。随着近几年来 JavaScript 的应用日渐广泛,滑动效果无处不在,于是我也跟跟风,将返回顶部功能做成了滑动效果。后来为了更贴合物理特征, 改造做成了减速的滑动效果。

首先说一下原理吧,我们会获取滚动条到页面顶部的距离,然后上移一定的距离;再获取滚动条到页面顶部的距离,上移一定的距离(比上一次小一点);以此类推 ... 可以500%提高开发效率的前端UI框架!

<script type="text/javascript"> 
/** 
 * 回到页面顶部 
 * @param acceleration 加速度 
 * @param time 时间间隔 (毫秒) 
 **/
function goTop(acceleration, time) { 
    acceleration = acceleration || 0.1; 
    time = time || 16; 
    
    var x1 = 0; 
    var y1 = 0; 
    var x2 = 0; 
    var y2 = 0; 
    var x3 = 0; 
    var y3 = 0; 
    
    if (document.documentElement) { 
        x1 = document.documentElement.scrollLeft || 0; 
        y1 = document.documentElement.scrollTop || 0; 
    } 
    if (document.body) { 
        x2 = document.body.scrollLeft || 0; 
        y2 = document.body.scrollTop || 0; 
    } 
    var x3 = window.scrollX || 0; 
    var y3 = window.scrollY || 0; 
    
    // 滚动条到页面顶部的水平距离 
    var x = Math.max(x1, Math.max(x2, x3)); 
    // 滚动条到页面顶部的垂直距离 
    var y = Math.max(y1, Math.max(y2, y3)); 
    
    // 滚动距离 = 目前距离 / 速度, 因为距离原来越小, 速度是大于 1 的数, 所以滚动距离会越来越小 
    var speed = 1 + acceleration; 
    window.scrollTo(Math.floor(x / speed), Math.floor(y / speed)); 
    
    // 如果距离不为零, 继续调用迭代本函数 
    if(x > 0 || y > 0) { 
        var invokeFunction = "goTop(" + acceleration + ", " + time + ")"; 
        window.setTimeout(invokeFunction, time); 
    } 
}  
</script>
 

document.documentElement.scrollTop, document.body.scrollTop, window.scrollY 其实都是一样的,但它们只在某些浏览器中起作用。至于那哪个在哪些浏览器起作用可以自己调试一下。可以500%提高开发效率的前端UI框架!

如何使用?

<a href="#" οnclick="goTop();return false;">TOP</a>
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的推箱子游戏的原生 JavaScript 代码: ```javascript // 定义地图 var map = [ [1, 1, 1, 1, 1], [1, 0, 0, 0, 1], [1, 0, 2, 0, 1], [1, 0, 0, 0, 1], [1, 1, 1, 1, 1] ]; // 定义人物和箱子的位置 var player = { x: 1, y: 1 }; var box = { x: 2, y: 2 }; // 渲染地图 function render() { var html = ''; for (var i = 0; i < map.length; i++) { for (var j = 0; j < map[i].length; j++) { if (i === player.y && j === player.x) { html += '👦'; } else if (i === box.y && j === box.x) { html += '📦'; } else if (map[i][j] === 1) { html += '🧱'; } else { html += ' '; } } html += '<br>'; } document.getElementById('map').innerHTML = html; } // 移动人物和箱子 function move(dx, dy) { var newPlayer = { x: player.x + dx, y: player.y + dy }; if (map[newPlayer.y][newPlayer.x] === 0) { player = newPlayer; render(); } else if (map[newPlayer.y][newPlayer.x] === 2) { var newBox = { x: box.x + dx, y: box.y + dy }; if (map[newBox.y][newBox.x] === 0) { player = newPlayer; box = newBox; render(); } } } // 监听键盘事件 document.addEventListener('keydown', function(event) { if (event.keyCode === 37) { // 左 move(-1, 0); } else if (event.keyCode === 38) { // 上 move(0, -1); } else if (event.keyCode === 39) { // 右 move(1, 0); } else if (event.keyCode === 40) { // 下 move(0, 1); } }); // 初始化 render(); ``` 你可以在 HTML 中添加一个 `div` 元素,id 为 `map`,然后将上面的 JavaScript 代码放在 `script` 标签中即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值