javascript - 在 Jquery 中隐藏和更改 div 元素

标签 javascript jquery html class-visibility

大家好,我需要你的帮助,我在网页上有两个按钮,当单击 button1 时,它下面会出现一个箭头,并且按钮的背景颜色会发生变化,当单击 button2 时,同样适用,但是 button1 下方的箭头消失并且背景颜色变化。

我已经实现了其中的大部分属性,但我无法弄清楚为什么在单击 button2 后返回到 button1 时,button2 下方的箭头没有隐藏。

这是我的代码

++++++++ HTML+++++++

 $(document).ready(function() {
                $('#select').click(function(){
                    $(this).css('background','#1169ff');
                    $(this).css('color','#ecf0f1');
                    $('#triangle_down').add('#triangle_down1').show();
                    if($('#select1').css('background','#1169ff') && $('#select1').css('color','#ecf0f1')){
                        $('#select1').css('background','#ecf0f1');
                        $('#select1').css('color','#1169ff');
                    } else if($('#triangle_down2').add('#triangle_down3').addClass('hidden')){
                        $('#triangle_down').add('#triangle_down1').show();
                    }


                });
                $('#select1').on('click', function() {
                    $(this).css('background','#1169ff');
                    $(this).css('color','#ecf0f1');
                    $('#triangle_down').add('#triangle_down1').addClass('hidden');
                    $('#select').css('background','#ecf0f1');
                    $('#select').css('color','#1169ff');
                    $('#triangle_down2').add('#triangle_down3').show();
                });

            })
#subscribe p{
text-align:center;
}
#subscribe input {
background: rgba(255, 255, 255, 0.52);
color: #666666;
vertical-align: middle;
width: 593px;
border: 1px solid rgba(255, 255, 255, 0.76);
padding: 0 10px;
height: 60px;
	font-size: 20px;
	outline: 0;
}
#subscribe input[type="submit"]{
background: rgb(255, 135, 19);
color: #ecf0f1;
/*width: auto;*/
padding: 14px 25px;
cursor: pointer;
margin-left: 50px
font-weight: bold; 
height: 60px;
display: inline-block;
border: 2px solid;
	font-size: 20px;
	outline: 0;
}

#subscribe button[id="select"],[id="select1"]{
background: #ecf0f1;
	width: 370px;
	height: 60px;
	/*padding-left: 100px;*/
	/*padding-right: 100px;*/
	padding: 0 10px;
	vertical-align: middle;
	font-size: 20px;
	outline: 0;
	color: #1169ff;
	border: 2px solid;
	text-align:center;

}

#subscribe input[id="main"] {
	width: 150px;
	outline: 0;
}
#triangle_down {

	position:absolute;
    width: 0;
    height: 0;
    border-top: 15px solid #1169ff;
    border-left: 9px solid transparent;
    border-right: 9px solid transparent;
	top:125px;
    left:90px;

}

#triangle_down1 {

	position:absolute;
    width: 0;
    height: 0;
    border-top: 20px solid #ecf0f1;
    border-left: 11px solid transparent;
    border-right: 11px solid transparent;
	top:125px;
    left:88px;

}
#triangle_down3 {

	position:absolute;
    width: 0;
    height: 0;
    border-top: 15px solid #1169ff;
    border-left: 9px solid transparent;
    border-right: 9px solid transparent;
	top:125px;
    left:464px;

}

#triangle_down2 {

	position:absolute;
    width: 0;
    height: 0;
    border-top: 20px solid #ecf0f1;
    border-left: 11px solid transparent;
    border-right: 11px solid transparent;
	top:125px;
    left:462px;

}
<div id="subscribe">
                <form action="" method="post" onsubmit="">
                    <p>

                        <button type="button" id="select">Acheter</button>
                        <button type="button" id="select1">Louer</button>

                    </p>


                  <!-- Using 2 traingles to achieve border outline :) -->
                    <i id="triangle_down1" style="display: none"><i></i></i>
                  <i id="triangle_down" style="display: none"><i></i></i><br/>

                    <!--Louer triangles -->
                  <i id="triangle_down2" style="display: none"><i></i></i>
                  <i id="triangle_down3" style="display: none"><i></i></i><br/>

                    <div></div>

                    <p><input name="" placeholder="Entrer une ville au Maroc" type="text" id="landing-entry"/>
                        <a href="/results"> <input type="submit" id="main" value="Search"/></a>
                    </p>
                </form>

谢谢

最佳答案

主要问题是您使用的是 .addClass('hidden')使用 .show()

jQuery 在显示、隐藏和切换方面有点变化无常,但它们在该元素上强加了一个内联样式到 display: hidden。或 display: show .您的“隐藏”类正在被 jQuery 放置的内嵌样式覆盖。

只要在显示和隐藏内容时保持一致即可。要么在线条样式中使用,例如添加/删除“隐藏”或“显示”类,要么使用 .show() , .hide() , 和 .toggle()来自 jQuery 的函数。

我清理了代码,并将其全部放在一个 jsfiddle 中。希望这有助于 https://jsfiddle.net/agayn7yn/

关于javascript - 在 Jquery 中隐藏和更改 div 元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34934433/

相关文章:

php - 我可以使用 jquery post 上传图片吗?

javascript - jQuery UI .effect() 不适用于 if..else 条件

javascript - Highchart 热图 - 日期时间 Y 轴对齐

javascript - 资源解释为文档,但使用 MIME 类型 application/json,laravel 进行传输

php - 如何在Jquery DataTable中添加编辑和打印按钮?

javascript - 如何将类数组字符串转换为数组

html - 如何在纯CSS中制作自定义复选框和单选按钮?

JavaScript:将 <div> 元素移到列中 2 个元素之后的右侧

javascript - 对JS对象的所有成员执行一个 Action

javascript - tablesorter jquery - 如何修复列标题