document.documentElement.scrollTop为零

var search = function () {
    /*1.默认固定顶部透明背景*/
    var searchBox = document.querySelector('.headBox');
    var banner = document.querySelector('.banner');
    var height = banner.offsetHeight;
    console.log(height);
    /*监听页面滚动事件*/
    window.onscroll = function () {
        var scrollTop = document.body.scrollTop;
        console.log(scrollTop);
        //console.log(scrollTop);
        /*默认的透明度*/
        var opacity = 0;
        if (scrollTop < height) {
            /*2.当页面滚动的时候---随着页面卷曲的高度变大透明度变大*/
            opacity = scrollTop / height * 0.85;
            console.log(height);
            console.log(scrollTop);
            console.log(opacity);
        } else {
            /*3.当页面滚动的时候---超过某一个高度的时候透明度不变*/
            opacity = 0.85;
        }
        searchBox.style.background = '-webkit-linear-gradient(left, rgba(2,124,187,'+opacity+'), rgba(217,228,131,'+opacity+'))';
    }
};

有没有发现:document.documentElement.scrollTop的仁始终为零,那是因为你的HTML文件加了这个:,所以DOM结构要改下:
原:document.body.scrollTop
改:document.documentElement.scrollTop
渐变加透明的效果是不是OK了呢?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
document.documentElement.scrollTop为0的原因可能是因为在Vue封装组件后,常常是在组件里面继续轮滑,而document.documentElement.scrollTop拿到的是最外层浏览器的轮滑高度,所以一直是0。\[1\]解决这个问题的方法是将原来的document.body.scrollTop改为document.documentElement.scrollTop。\[2\]另外,为了兼容所有浏览器,可以封装一个函数来获取页面向上卷曲出去的距离,可以使用以下代码:top: window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0。\[3\]这样可以确保在不同浏览器中都能正确获取到页面向上卷曲出去的距离。 #### 引用[.reference_title] - *1* [vue js document.documentElement.scrollTop获取一直为0的解决方法](https://blog.csdn.net/daishaochen/article/details/126866645)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [document.documentElement.scrollTop](https://blog.csdn.net/minpad/article/details/89376485)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [document.body.scrollTop的值总为的解决办法](https://blog.csdn.net/weixin_42929937/article/details/121332022)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值