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

直接上代碼,js是主要寫的部分,css是隨意調(diào)試的,不過這個寫法要用到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");
//對所有的h2綁定一個點(diǎn)擊事件
for (let i = 0; i <h2.length ; i++) {
h2[i].index = i;
h2[i].onclick = function () {
//綁定的事件是如果和h2在同一級的ul沒有classname的話,就給他的classname取名為ul,如果有的話,就給他的classname置為空。
//通過css代碼可以看到有一個.ul的部分是不起作用的,因?yàn)閖s還沒有給相應(yīng)的h2的classname改變,當(dāng)點(diǎn)擊h2的時候才會改變。
//這個寫法就是不直接改變css樣式內(nèi)容,而是通過改變名字來實(shí)現(xiàn)樣式的轉(zhuǎn)變,這樣的話,一個樣式就能被用好多次,不用重復(fù)一直寫樣式。
if (ul[this.index].className == ""){
ul[this.index].className = "ul";
}else {
ul[this.index].className = "";
}
}
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- js實(shí)現(xiàn)下拉列表選中某個值的方法(3種方法)
- jquery用ajax方式從后臺獲取json數(shù)據(jù)后如何將內(nèi)容填充到下拉列表
- jquery+json 通用三級聯(lián)動下拉列表
- javaScript年份下拉列表框內(nèi)容為當(dāng)前年份及前后50年
- js獲取下拉列表框<option>中的value和text的值示例代碼
- extJs 文本框后面加上說明文字+下拉列表選中值后觸發(fā)事件
- javascript級聯(lián)下拉列表實(shí)例代碼(自寫)
- javascript實(shí)現(xiàn)在下拉列表中顯示多級樹形菜單的方法
- javascript獲取下拉列表框當(dāng)中的文本值示例代碼
- 使用js實(shí)現(xiàn)一個可編輯的select下拉列表
相關(guān)文章
Javascript限制網(wǎng)頁只能在微信內(nèi)置瀏覽器中訪問
最近正在開發(fā)一個微信公眾賬號,其中有一項(xiàng)功能是用戶發(fā)送文字消息給公眾號,然后公眾號返回圖文消息給用戶,用戶再點(diǎn)擊圖文消息即可跳轉(zhuǎn)到一個網(wǎng)頁鏈接,在微信的內(nèi)置瀏覽器中打開。2014-11-11
Javascript 中的 call 和 apply使用介紹
JavaScript 中通過call或者apply用來代替另一個對象調(diào)用一個方法,將一個函數(shù)的對象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對象2012-02-02
JavaScript實(shí)現(xiàn)動態(tài)表格的方法詳解
這篇文章主要為大家介紹了JavaScript實(shí)現(xiàn)動態(tài)表格的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-01-01
微信小程序?qū)崿F(xiàn)自動播放視頻模仿gif動圖效果實(shí)例
這篇文章主要給大家介紹了關(guān)于微信小程序?qū)崿F(xiàn)自動播放視頻模仿gif動圖效果的相關(guān)資料,通過本文介紹的方法可以實(shí)現(xiàn)自動播放視頻,視頻無控制條無聲音且自動循環(huán)播放,需要的朋友可以參考下2021-07-07
微信小程序使用slider設(shè)置數(shù)據(jù)值及switch開關(guān)組件功能【附源碼下載】
這篇文章主要介紹了微信小程序使用slider設(shè)置數(shù)據(jù)值及switch開關(guān)組件功能,結(jié)合實(shí)例形式分析了slider組件及switch組件的功能與使用方法,并附帶源碼供讀者下載參考,需要的朋友可以參考下2017-12-12
JS+CSS實(shí)現(xiàn)的拖動分頁效果實(shí)例
這篇文章主要介紹了JS+CSS實(shí)現(xiàn)的拖動分頁效果,可實(shí)現(xiàn)鼠標(biāo)拖動頁面翻轉(zhuǎn)到上一頁或下一頁的功能,涉及javascript操作頁面元素與css樣式的相關(guān)技巧,需要的朋友可以參考下2015-05-05

