React操作真实DOM实现动态吸底部的示例

网友投稿 429 2023-03-24


React操作真实DOM实现动态吸底部的示例

动态吸底:开始时fixed在页面上,当页面滚动到距离底部一定距离的时fixed部分固TJrPbz定。

这个是需要计算页面滚动距离的,如果使用jquery或者原生js实现是非常好实现的,但是由于使用react并不推崇操作DOM,但是如果使用virtual DOM的话是无法实现该效果的,所以还是要引入js去直接获取DOM进行操作。

react在componentDidMount之后页面渲染完成,所以可以在这里面直接用js原生方法获取DOM元素,进而进行操作。

componentDidMount() {

this.changeFixed()

}

//計算高度

changeFixed(){

//getDOMNode

const layoutNode = document.querySelectorAll('.page-layout')[0];

const ordehttp://rPriceNode = document.querySelectorAll('.test-price')[0];

window.addEventListener('scroll', function (e) {

const windowInnerHeight = window.innerHeight;

const layoutNodeHeight = layoutNode.offsetHeight;

//滚动超出视野距离

let scrollTop = window.pageYOffset|| document.documentElement.scrollTop || document.TJrPbzbody.scrollTop;

const distanceBottom = layoutNodeHeight - scrollTop - windowInnerHeight;

//120的时候吸底

if(distanceBottom <= 120){

orderPriceNode.classList.remove('fixed');

}else{

orderPriceNode.classList.add('fixed');

}

})

}

这样就实现了当距离底部120的时候吸底


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java中IO流文件读取、写入和复制的实例
下一篇:使用ionic(选项卡栏tab) icon(图标) ionic上拉菜单(ActionSheet) 实现通讯录界面切换实例代码
相关文章

 发表评论

暂时没有评论,来抢沙发吧~