本文实例为大家分享了Javascript实现单选框效果的具体代码,供大家参考,具体内容如下
描述: 点击每一个li 将li的内容赋值给 div 给当前点击的li加上背景色, 点击空白部分隐藏
技术要点:
1.事件委托
事件委托: 事件代理, 将子节点要做的事情交给父元素来做
原理: 将原来要给子元素添加的事件, 加给父元素, 事件中通过 target || srcElement 找到对应的子节点, 子节点处理具体的操作
优点: 避免使用for 后续加进来的元素也有同样的事件处理
使用: 如果子节点有统一的事件(每一个li都加点击事件 每一个li都输出元素)
1
2
3
4
5
6
7
8
9
10
11
12
|
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' ;
}
// 创建节点
var li = document.createElement( 'li' );
li.innerHTML = '12345' ;
// 追加进去
ul.appendChild(li);
|
2.阻止冒泡
由于冒泡产生的问题 阻止冒泡解决
依赖于事件对象
标准: ev.stopPropagation();
ie: ev.cancelBubble = true;
一个是方法 一个是属性 需要做兼容
判断方法是否存在:
1
|
ev.stopPropagation ? ev.stopPropagation() : ev.cancelBubble = true ;
|
不想让哪一个事件冒泡,就在那一个元素的事件上阻止
代码实现:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
<!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的内容赋值给 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不会触发父元素事件
div.onmouseenter = function(){
ul.style.display = 'block';
/* 将li的内容赋值给 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);
// 获取事件的触发源
var tar = ev .target || ev.srcElement;
// div的内容更改为相对应触发源的内容
div.innerHTML = tar .innerHTML;
// 给当前点击的li加上背景色
tar.style.background = '#0000FF' ;
tar.style.color = '#fff5bd' ;
}
}
// 点击空白处隐藏
document.onclick = function (){
// ul消失
ul.style.display = 'none' ;
// div的值设为空
div.innerHTML = '' ;
// 所有li恢复原来样式
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添加划出事件, 恢复为默认样式
lis[i] .onmouseleave = function (){
this.style.background = '#ffffff' ;
this.style.color = '#000000' ;
}
}
</script>
</ body >
</ html >
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/qq_37086980/article/details/110870969