JavaScript實(shí)現(xiàn)下拉列表
本文實(shí)例為大家分享了JavaScript實(shí)現(xiàn)下拉列表的具體代碼,供大家參考,具體內(nèi)容如下
這一次寫了一個(gè)比較簡(jiǎn)單的下拉列表的實(shí)現(xiàn),點(diǎn)擊出現(xiàn)列表內(nèi)容,再次點(diǎn)擊列表消失,研究了很久,發(fā)現(xiàn)這種js寫法確實(shí)比較好用。先看一下效果。

直接上代碼,js是主要寫的部分,css是隨意調(diào)試的,不過這個(gè)寫法要用到css。
1、HTML部分的代碼
<body> <!--最外面的一層--> <div class="outer"> <!-- 里面的--> <div class="inner"> <h2>第一</h2> <ul> <li>a</li> <li>b</li> <li>c</li> </ul> </div> <div class="inner"> <h2>第二</h2> <ul> <li>1</li> <li>2</li> <li>3</li> </ul> </div> <div class="inner"> <h2>第二</h2> <ul> <li>4</li> <li>5</li> <li>6</li> </ul> </div> <div class="inner"> <h2>第二</h2> <ul> <li>7</li> <li>8</li> <li>9</li> </ul> </div> <!-- 里面的--> </div> <!--最外面一層--> </body>
2、css部分的代碼
.outer{
margin: 0 auto;
width: 500px;
height: 600px;
border: 1px solid red;
}
.outer .inner{
width: 500px;
border: 1px solid red;
}
.outer .inner ul{
list-style: none;
border: 1px solid fuchsia;
}
h2{
border: 1px solid blueviolet;
height: 30px;
display: flex;
justify-content: center;
cursor: pointer;
background-color: #74a400;
margin: 0;
}
ul{
display: none;
}
這里.ul是HTML里面沒有的,要通過js來添加
.ul{
display: block;
background-color: cornflowerblue;
margin: 0;
}
ul li{
border: 1px solid cornflowerblue;
background-color: darkgray;
display: flex;
justify-content: center;
margin-left: -42px;
cursor: pointer;
}
3、最重要的js代碼部分
window.onload = function () {
// 獲取h2與ul
var h2 = document.getElementsByTagName("h2");
var ul = document.getElementsByTagName("ul");
//對(duì)所有的h2綁定一個(gè)點(diǎn)擊事件
for (let i = 0; i <h2.length ; i++) {
h2[i].index = i;
h2[i].onclick = function () {
//綁定的事件是如果和h2在同一級(jí)的ul沒有classname的話,就給他的classname取名為ul,如果有的話,就給他的classname置為空。
//通過css代碼可以看到有一個(gè).ul的部分是不起作用的,因?yàn)閖s還沒有給相應(yīng)的h2的classname改變,當(dāng)點(diǎn)擊h2的時(shí)候才會(huì)改變。
//這個(gè)寫法就是不直接改變css樣式內(nèi)容,而是通過改變名字來實(shí)現(xiàn)樣式的轉(zhuǎn)變,這樣的話,一個(gè)樣式就能被用好多次,不用重復(fù)一直寫樣式。
if (ul[this.index].className == ""){
ul[this.index].className = "ul";
}else {
ul[this.index].className = "";
}
}
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- js實(shí)現(xiàn)下拉列表選中某個(gè)值的方法(3種方法)
- jquery用ajax方式從后臺(tái)獲取json數(shù)據(jù)后如何將內(nèi)容填充到下拉列表
- jquery+json 通用三級(jí)聯(lián)動(dòng)下拉列表
- javaScript年份下拉列表框內(nèi)容為當(dāng)前年份及前后50年
- js獲取下拉列表框<option>中的value和text的值示例代碼
- extJs 文本框后面加上說明文字+下拉列表選中值后觸發(fā)事件
- javascript級(jí)聯(lián)下拉列表實(shí)例代碼(自寫)
- javascript實(shí)現(xiàn)在下拉列表中顯示多級(jí)樹形菜單的方法
- javascript獲取下拉列表框當(dāng)中的文本值示例代碼
- 使用js實(shí)現(xiàn)一個(gè)可編輯的select下拉列表
相關(guān)文章
JS實(shí)現(xiàn)可調(diào)整倒計(jì)時(shí)間代碼分享
這篇文章主要介紹了JS實(shí)現(xiàn)可調(diào)整倒計(jì)時(shí)間代碼,效果很酷炫,也很具有實(shí)用價(jià)值,感興趣的小伙伴們可以參考一下2015-08-08
JS實(shí)現(xiàn)星星評(píng)分功能實(shí)例代碼(兩種方法)
這篇文章主要介紹了JS實(shí)現(xiàn)星星評(píng)分功能實(shí)例代碼(兩種方法)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06
JavaScript庫(kù)之vanilla-tilt使用教程(一個(gè)平滑的3D傾斜庫(kù))
vanilla-tilt.js是Javascript中一個(gè)平滑的3D傾斜庫(kù),可以讓網(wǎng)頁(yè)的一些控件變得動(dòng)態(tài)起來,下面這篇文章主要給大家介紹了關(guān)于JavaScript庫(kù)之vanilla-tilt使用的相關(guān)資料,需要的朋友可以參考下2023-02-02
js替換字符串中所有指定的字符(實(shí)現(xiàn)代碼)
下面小編就為大家?guī)硪黄猨s替換字符串中所有指定的字符(實(shí)現(xiàn)代碼)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-08-08
基于JavaScript實(shí)現(xiàn)活動(dòng)倒計(jì)時(shí)效果
這篇文章主要為大家詳細(xì)介紹了基于JavaScript實(shí)現(xiàn)活動(dòng)倒計(jì)時(shí)效果,距離活動(dòng)時(shí)間還剩多少,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04
JavaScript利用Date實(shí)現(xiàn)簡(jiǎn)單的倒計(jì)時(shí)實(shí)例
在日常開發(fā)的時(shí)候經(jīng)常遇到關(guān)于倒計(jì)時(shí)的需求,下面這篇文章就給主要介紹了JavaScript利用Date實(shí)現(xiàn)倒計(jì)時(shí)效果的方法示例,文中主要實(shí)現(xiàn)了倒計(jì)時(shí)和倒計(jì)時(shí)結(jié)束搶購(gòu)的按鈕才可以被點(diǎn)擊的效果,有需要的朋友可以參考借鑒。2017-01-01
JavaScript中幾種時(shí)間格式之間的簡(jiǎn)單轉(zhuǎn)換
近期在練習(xí)或?qū)戫?xiàng)目時(shí)經(jīng)常會(huì)遇到時(shí)間格式的轉(zhuǎn)換問題,今天我就來總結(jié)一下,這篇文章主要給大家介紹了關(guān)于JavaScript中幾種時(shí)間格式之間的簡(jiǎn)單轉(zhuǎn)換,需要的朋友可以參考下2024-01-01

