扫码关注官方订阅号
我在浏览器scroll事件中不断改变一个元素的top值,元素top值的改变为什么不流畅,一跳一跳的,怎么才能解决
拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...
推荐使用基于jQuery的animate动画函数以及scrollTop方法,平稳过渡效果,时间可控制,封装代码如下:
animate
scrollTop
/** * 自动页面滚动至某元素 * @param {Object} obj 主对象 * @param {Number} time 页面滚动至某元素所需时间 * @example autoscroll($('#goTop'),100) */ function autoscroll(obj,time){ var $this = $(obj); if(!time) time = 500; var $top = $this.offset().top; $('html,body').animate({ scrollTop:$top },time); }
将滚动回调函数中使用到的对象之类的,除非需要根据条件计算的,其他的通通先用变量缓存起来。这样在某些情况下是可以实现一定程度的优化的。
不要直接操作元素的值,最好用变量代替元素值的变化,前段性能优化中就有尽量减少dom元素操作
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
推荐使用基于jQuery的
animate动画函数以及scrollTop方法,平稳过渡效果,时间可控制,封装代码如下:将滚动回调函数中使用到的对象之类的,除非需要根据条件计算的,其他的通通先用变量缓存起来。这样在某些情况下是可以实现一定程度的优化的。
不要直接操作元素的值,最好用变量代替元素值的变化,前段性能优化中就有尽量减少dom元素操作