时间:2021-05-26
本文实例为大家分享了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'; // 获取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>以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了JS面向对象之单选框实现代码,供大家参考,具体内容如下描述:JS面向对象——单选框的实现效果:实现:Utile.js(function(){
HTML5单选框、复选框、下拉菜单、文本域单选框的实例代码,代码如下所示:1单选框代码:效果:复选框2复选框代码:篮球足球羽毛球唱歌画画敲代码阅读效果;下拉菜单
本文主要介绍了AmazeUI单选框和多选框的实现示例,分享给大家,也给自己留个笔记,具体如下:单选框和多选框复选框没有选中已选中禁用/未选中禁用/已选中单选框未
本文实例讲述了js实现表单Radio切换效果的方法。分享给大家供大家参考。具体如下:这里基于js实现表单中的Radio单选框切换效果,当选中某个单选框的时候,所
本文实例讲述了js实现iPhone界面风格的单选框和复选框按钮。分享给大家供大家参考。具体如下:这里使用JS美化仿iPhone风格的单选框和复选框按钮效果,使用