Javascript實現(xiàn)單選框效果
本文實例為大家分享了Javascript實現(xiàn)單選框效果的具體代碼,供大家參考,具體內(nèi)容如下
描述: 點擊每一個li 將li的內(nèi)容賦值給 div 給當前點擊的li加上背景色, 點擊空白部分隱藏

技術(shù)要點:
1.事件委托
事件委托: 事件代理, 將子節(jié)點要做的事情交給父元素來做
原理: 將原來要給子元素添加的事件, 加給父元素, 事件中通過 target || srcElement 找到對應(yīng)的子節(jié)點, 子節(jié)點處理具體的操作
優(yōu)點: 避免使用for 后續(xù)加進來的元素也有同樣的事件處理
使用: 如果子節(jié)點有統(tǒng)一的事件(每一個li都加點擊事件 每一個li都輸出元素)
ul.onclick = function(evs){
var ev = window.event || evs;
// console.log(ev.target || ev.srcElement);
var tar = ev.target || ev.srcElement;
tar.style.background = 'red';
}
// 創(chuàng)建節(jié)點
var li = document.createElement('li');
li.innerHTML = '12345';
// 追加進去
ul.appendChild(li);
2.阻止冒泡
由于冒泡產(chǎn)生的問題 阻止冒泡解決
依賴于事件對象
標準: ev.stopPropagation();
ie: ev.cancelBubble = true;
一個是方法 一個是屬性 需要做兼容
判斷方法是否存在:
ev.stopPropagation ? ev.stopPropagation() : ev.cancelBubble = true;
不想讓哪一個事件冒泡,就在那一個元素的事件上阻止
代碼實現(xiàn):
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>模擬單選框</title>
<style>
*{
margin: 0;
padding: 0;
}
div{
width: 260px;
height: 30px;
border: 1px solid #0000ff;
margin: 40px auto;
font: 14px/30px "微軟雅黑";
text-indent: 5px;
}
ul{
width: 260px;
height: 150px;
border: 1px solid #0000ff;
margin: -40px auto;
display: none;
}
ul > li{
list-style: none;
width: 100%;
height: 30px;
font: 14px/30px "微軟雅黑";
text-indent: 5px;
}
ul > li:hover{
color:#fff5bd;
background: #fe6601;
}
</style>
</head>
<body>
<!-- 1.布局: div 和 列表 并且劃上加背景色 -->
<div id="content"></div>
<ul>
<li>HTML</li>
<li>CSS</li>
<li>JavaScript</li>
<li>HTML5</li>
<li>CSS3</li>
</ul>
<script>
// 點擊每一個li 將li的內(nèi)容賦值給 div 給當前點擊的li加上背景色
// 點擊空白部分隱藏
// 1.當鼠標移入div時, ul顯示, 反之ul隱藏
// 獲取div, ul
var div = document.querySelector('div');
var ul = document.querySelector('ul');
var lis = ul.getElementsByTagName('li');
console.log(div, ul, lis);
// 鼠標移入div時, ul顯示, onmouseenter不會觸發(fā)父元素事件
div.onmouseenter = function(){
ul.style.display = 'block';
/* 將li的內(nèi)容賦值給 div 給當前點擊的li加上背景色
獲取點擊的li的值 */
// 獲取ul點擊事件
ul.onclick = function(evs){
// 增加排他操作
for(var i = 0; i < lis.length; i++){
lis[i].style.background = '#ffffff';
lis[i].style.color = '#000000';
}
// 獲取事件
var ev = window.event || evs;
// 阻止冒泡
ev.stopPropagation ? ev.stopPropagation() : ev.cancelBubble = true;
// console.log(ev.target || ev.srcElement);
// 獲取事件的觸發(fā)源
var tar = ev.target || ev.srcElement;
// div的內(nèi)容更改為相對應(yīng)觸發(fā)源的內(nèi)容
div.innerHTML = tar.innerHTML;
// 給當前點擊的li加上背景色
tar.style.background = '#0000FF';
tar.style.color = '#fff5bd';
}
}
// 點擊空白處隱藏
document.onclick = function(){
// ul消失
ul.style.display = 'none';
// div的值設(shè)為空
div.innerHTML = '';
// 所有l(wèi)i恢復(fù)原來樣式
for(var i = 0; i < lis.length; i++){
lis[i].style.background = '#ffffff';
lis[i].style.color = '#000000';
}
}
// 給每一個li添加劃上屬性
for(var i = 0; i < lis.length; i++){
// 為li添加劃上事件
lis[i].onmouseenter = function(){
this.style.background = '#fe6601';
this.style.color = '#fff5bd';
}
// 為li添加劃出事件, 恢復(fù)為默認樣式
lis[i].onmouseleave = function(){
this.style.background = '#ffffff';
this.style.color = '#000000';
}
}
</script>
</body>
</html>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript實現(xiàn)的浮動層框架用法實例分析
這篇文章主要介紹了JavaScript實現(xiàn)的浮動層框架用法,以實例形式分析了JavaScript實現(xiàn)可關(guān)閉的半透明浮動層相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-10-10
JavaScript中最常用的10種代碼簡寫技巧總結(jié)
這篇文章主要總結(jié)了JavaScript中最常用的10種代碼簡寫技巧的相關(guān)資料,其中包括三元操作符、短路求值簡寫方式、聲明變量簡寫方法、if存在條件簡寫方法及JavaScript循環(huán)簡寫方法等等,分別給出了詳細的示例代碼供大家參考,需要的朋友們下面來一起看看吧。2017-06-06

