gpt4 book ai didi

JavaScript getElementById 无法在手机上运行

转载 作者:行者123 更新时间:2023-11-28 03:09:01 24 4
gpt4 key购买 nike

我正在创建一个包含一些 JavaScript 代码的网站。 JavaScript 的所有内容在计算机上都运行良好。但在我的 iPhone 7 上,getElementById 函数不起作用。我尝试设置 img 标签的来源,但没有任何反应。

JavaScript:

var header_bar = $('.js-header-bar, .js-header-bar-mobile');
var header_bar_mobile = $('.js-header-bar-mobile');
var header_bar_navbar = header_bar_mobile.find('.navbar-primary');
var header_bar_toggler = header_bar_mobile.find('.navbar-toggler');
var header_bar_offsetTop = header_bar.offset().top;

$(window).on('scroll', onScroll);
function onScroll(){
if ($(this).scrollTop() > header_bar_offsetTop){
header_bar.addClass("sticky");
document.getElementById("headerLogo").src = "images/logo-black.png";


} else {
header_bar.removeClass("sticky");
document.getElementById('headerLogo').src = "images/logo-white.png";
}
}

该功能应该在网站顶部添加一个黑色 Logo ,如果我滚动一个白色 Logo 。在计算机上它可以工作,但在我的智能手机上则不行。

HTML:

<header class="header header-mobile js-header-bar-mobile d-md-none">
<div class="header-bar">
<div class="header-bar-logo">
<a href="index.html">
<img class="originalTest" alt='Auto mit Schriftzug: "Autohandel-ZAR"' id="headerLogo" src="images/logo-white.png"/>
</a>
</div>
<div class="header-bar-menu">
<button class="navbar-toggler hamburger" type="button" id="js-header-toggle">
<span class="hamburger-box">
<span class="hamburger-inner"></span>
</span>
</button>
</div>
</div>

提前谢谢您。

最佳答案

为移动设备添加额外的事件监听器:

$(document.body).on('touchmove', onScroll);

所以完整的代码应该如下所示:

var header_bar = $('.js-header-bar, .js-header-bar-mobile');
var header_bar_mobile = $('.js-header-bar-mobile');
var header_bar_navbar = header_bar_mobile.find('.navbar-primary');
var header_bar_toggler = header_bar_mobile.find('.navbar-toggler');
var header_bar_offsetTop = header_bar.offset().top;

$(document.body).on('touchmove', onScroll);
$(window).on('scroll', onScroll);
function onScroll(){
if ($(this).scrollTop() > header_bar_offsetTop){
header_bar.addClass("sticky");
document.getElementById("headerLogo").src = "images/logo-black.png";


} else {
header_bar.removeClass("sticky");
document.getElementById('headerLogo').src = "images/logo-white.png";
}
}

关于JavaScript getElementById 无法在手机上运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60336425/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com