Javascript实现单选框效果
作者:夹心776655 发布时间:2024-04-23 09:06:42
标签:js,单选框
本文实例为大家分享了Javascript实现单选框效果的具体代码,供大家参考,具体内容如下
描述: 点击每一个li 将li的内容赋值给 div 给当前点击的li加上背景色, 点击空白部分隐藏
技术要点:
1.事件委托
事件委托: 事件代理, 将子节点要做的事情交给父元素来做
原理: 将原来要给子元素添加的事件, 加给父元素, 事件中通过 target || srcElement 找到对应的子节点, 子节点处理具体的操作
优点: 避免使用for 后续加进来的元素也有同样的事件处理
使用: 如果子节点有统一的事件(每一个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';
}
// 创建节点
var li = document.createElement('li');
li.innerHTML = '12345';
// 追加进去
ul.appendChild(li);
2.阻止冒泡
由于冒泡产生的问题 阻止冒泡解决
依赖于事件对象
标准: ev.stopPropagation();
ie: ev.cancelBubble = true;
一个是方法 一个是属性 需要做兼容
判断方法是否存在:
ev.stopPropagation ? ev.stopPropagation() : ev.cancelBubble = true;
不想让哪一个事件冒泡,就在那一个元素的事件上阻止
代码实现:
<!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


猜你喜欢
- 本文介绍了解决Vue2.0自带浏览器里无法打开的原因(兼容处理),分享给大家,希望对大家有帮助Vue 之 android内嵌H5页面不显示出
- 一、安装redis因为是在CentOS系统下安装的,并且是服务器。遇到的困难有点多不过。1.首先要下载相关依赖首先先检查是否有c语言的编译环
- 数据库自增 ID搞一个数据库,什么也不干,就用于生成主键。你的系统里每次得到一个 id,都需要往那个专门生成主键的数据库中通过插入
- 本文实例汇总了Python中关于列表的常用操作方法,供大家参考借鉴。具体方法如下:一、Python创建列表:sample_list = [&
- Supervisor 是基于 Python 的进程管理工具,只能运行在 Unix-Like 的系统上,也就是无法运行在 Windows 上。
- 1:安装xlsx和file-savernpm install file-saver xlsx --save2:创建localEx
- Java 8终于到来了! 经过几年的等待, java程序员终于能在java中得到函数式编程的支持了. 函数式编程的支持能流程化现
- pytorch中基本的变量类型当属FloatTensor(以下都用floattensor),而Variable(以下都用variable)是
- 多子图figure是绘制对象(可以理解为一个空白的画布),一个figure对象可以包含多个Axes子图,一个Axes是一个绘图区域,不加设置
- 视频本教程的视频选择图形我们谈到了 Opengameart.org,这是免费游戏艺术的重要来源,也是我们最喜欢的艺术家之一&ldqu
- 在单个HTML元素上利用CSS2.1实现拥有3张背景图片和2张内容图效果,或者多重边框的效果。这种渐进增强的方式适用于所有支持CSS2.1伪
- 很多应用要用到TreeView来显示组织机构,以下演示TreeView如何与数据库进行绑定。数据库结构如下(递归现实):id(guid)&n
- 下面从以下四种方案分析各自的优缺点。方案一:SELECT * FROM `table` ORDER BY RAND() LIMIT 0,1;
- Capstone是Kali Linux自带的一款轻量级反汇编引擎。它可以支持多种硬件构架,如ARM、ARM64、MIPS、X86。该框架使用
- 对比测试 scipy.misc 和 PIL.Image 和 libtiff.TIFF 三个库输入:1. (读取矩阵) 读入uint8、uin
- CSS是制作网页效果必不可少的东西,字体的颜色定义、表格的样式定义、图片的特效等等都少不了它。但在Dr
- Python项目文件中安装 setup.py安装 setup.py 的过程与安装其他的 Python 包的过程类似。首先,你需要下载或者使用
- 我看过一篇关于程序员写博客的文章,他说很多的程序员过了两年写了很多的代码,但是回想起来自己具体做了哪些技术点,遇到坑几乎没有印象,所以说文字
- kafka go库kafka go客户端官方目前没有提供,但在github有2个非常流行的库星星较多,网上案例也多 https://gith
- 50个常用sql语句 Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 SC(