- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
所以我有三个按钮。我想通过单击其中一个按钮来更改横幅的背景图像。我试图用我在下面给你的功能来设置它。它应该按 id 获取按钮并更改类(class)横幅的背景图像。我究竟做错了什么 ?如果它改变了什么,我也会使用 sass。
代码如下:
function changebackground() {
button1.addEventListener('click', function() {
document.getElementsByClassName('banner').style.bacgkroundImage = "url(".. / images / banner - img.png ")";
})
button2.addEventListener('click', function() {
document.getElementsByClassName('banner').style.bacgkroundImage = "url(".. / images / banner - img2.png ")";
})
button3.addEventListener('click', function() {
document.getElementsByClassName('banner').style.bacgkroundImage = "url(".. / images / banner - img3.png ")";
})
}
.banner {
background-image: url("https://via.placeholder.com/150 ");
background-repeat: no-repeat;
background-size: cover;
width: 100%;
height: 570px;
z-index: 1;
padding-top: 50px;
position: relative;
}
.banner .carousel {
top: 50%;
position: absolute;
}
.banner .carousel .button {
height: 10px;
width: 10px;
border: 2px solid white;
margin: 10px;
border-radius: 9px;
position: relative;
}
.banner .carousel .button .first {
position: absolute;
margin-top: 3px;
margin-left: 3px;
height: 4px;
width: 4px;
border-radius: 5px;
background: #fea100;
}
.banner .banner-text {
font-family: "Playfair Display";
font-weight: 700;
position: absolute;
color: #fff;
left: 15%;
top: 40%;
z-index: 2;
}
}
<div class="banner">
<div class="carousel">
<div class="button" id="button1">
<div class="first"></div>
</div>
<div class="button" id="button2">
<div class="second"></div>
</div>
<div class="button" id="button3">
<div class="third"></div>
</div>
</div>
<div class="banner-text">
<h1>Test your fav dish</h1>
<h2>from <span>luxury restaurent</span></h2>
</div>
</div>
最佳答案
您的代码中存在一些错误:
changebackground
。如果不先调用此方法,您的事件处理程序将永远不会执行getElementsByClassName
返回一个数组,因此您必须使用 [0]
访问以获取 div.banner
元素bacgkroundImage
应该是 backgroundImage
"url("../images/banner - img3.png")"
应该是 "url('../images/banner - img3.png')"
function changebackground() {
document.getElementById('button1').addEventListener('click', function() {
document.getElementsByClassName('banner')[0].style.backgroundImage = "url('https://via.placeholder.com/150/0000FF/808080')";
})
button2.addEventListener('click', function() {
document.getElementsByClassName('banner')[0].style.backgroundImage = "url('https://via.placeholder.com/150/FF0000/FFFFFF')";
})
button3.addEventListener('click', function() {
document.getElementsByClassName('banner')[0].style.backgroundImage = "url('https://via.placeholder.com/150/FFFF00/000000')";
})
}
changebackground();
.banner {
background-image: url("https://via.placeholder.com/150 ");
background-repeat: no-repeat;
background-size: cover;
width: 100%;
height: 270px;
z-index: 1;
padding-top: 50px;
position: relative;
}
.banner .carousel {
top: 50%;
position: absolute;
}
.banner .carousel .button {
height: 10px;
width: 10px;
border: 2px solid white;
margin: 10px;
border-radius: 9px;
position: relative;
}
.banner .carousel .button .first {
position: absolute;
margin-top: 3px;
margin-left: 3px;
height: 4px;
width: 4px;
border-radius: 5px;
background: #fea100;
}
.banner .banner-text {
font-family: "Playfair Display";
font-weight: 700;
position: absolute;
color: #fff;
left: 15%;
top: 40%;
z-index: 2;
}
}
<div class="banner">
<div class="carousel">
<div class="button" id="button1">
<div class="first"></div>
</div>
<div class="button" id="button2">
<div class="second"></div>
</div>
<div class="button" id="button3">
<div class="third"></div>
</div>
</div>
<div class="banner-text">
<h1>Test your fav dish</h1>
<h2>from <span>luxury restaurent</span></h2>
</div>
</div>
关于javascript - 单击更改背景图像不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55656281/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!