电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Javascript實現單選框效果

瀏覽:4日期:2023-06-12 18:19:04

本文實例為大家分享了Javascript實現單選框效果的具體代碼,供大家參考,具體內容如下

描述: 點擊每一個li 將li的內容賦值給 div 給當前點擊的li加上背景色, 點擊空白部分隱藏

Javascript實現單選框效果

技術要點:

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>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 佛山市钱丰金属不锈钢蜂窝板定制厂家|不锈钢装饰线条|不锈钢屏风| 电梯装饰板|不锈钢蜂窝板不锈钢工艺板材厂家佛山市钱丰金属制品有限公司 | 鲁网 - 山东省重点新闻网站,山东第一财经门户 | 开锐教育-学历提升-职称评定-职业资格培训-积分入户 | 生产自动包装秤_颗粒包装秤_肥料包装秤等包装机械-郑州鑫晟重工科技有限公司 | LCD3D打印机|教育|桌面|光固化|FDM3D打印机|3D打印设备-广州造维科技有限公司 | 电子元器件呆滞料_元器件临期库存清仓尾料_尾料优选现货采购处理交易商城 | 超声波焊接机_超音波熔接机_超声波塑焊机十大品牌_塑料超声波焊接设备厂家 | 耐高温硅酸铝板-硅酸铝棉保温施工|亿欧建设工程 | 无线讲解器-导游讲解器-自助讲解器-分区讲解系统 品牌生产厂家[鹰米讲解-合肥市徽马信息科技有限公司] | 即用型透析袋,透析袋夹子,药敏纸片,L型涂布棒-上海桥星贸易有限公司 | 塑料撕碎机_编织袋撕碎机_废纸撕碎机_生活垃圾撕碎机_废铁破碎机_河南鑫世昌机械制造有限公司 | 西宁装修_西宁装修公司-西宁业之峰装饰-青海业之峰墅级装饰设计公司【官网】 | 探伤仪,漆膜厚度测试仪,轮胎花纹深度尺厂家-淄博创宇电子 | 济南拼接屏_山东液晶拼接屏_济南LED显示屏—维康国际官网 | 屏蔽服(500kv-超高压-特高压-电磁)-徐吉电气 | 注塑_注塑加工_注塑模具_塑胶模具_注塑加工厂家_深圳环科 | 洁净棚-洁净工作棚-无菌室-净化工程公司_北京卫护科技有限公司 | 山东钢格板|栅格板生产厂家供应商-日照森亿钢格板有限公司 | 橡胶弹簧|复合弹簧|橡胶球|振动筛配件-新乡市永鑫橡胶厂 | 共享雨伞_共享童车_共享轮椅_共享陪护床-共享产品的领先者_有伞科技 | 深圳南财多媒体有限公司介绍 | 吨袋包装机|吨包秤|吨包机|集装袋包装机-烟台华恩科技 | 深圳办公室装修-写字楼装修设计-深圳标榜装饰公司 | 油罐车_加油机_加油卷盘_加油机卷盘_罐车人孔盖_各类球阀_海底阀等车用配件厂家-湖北华特专用设备有限公司 | 集菌仪_智能集菌仪_全封闭集菌仪_无菌检查集菌仪厂家-那艾 | 菲希尔FISCHER测厚仪-铁素体检测仪-上海吉馨实业发展有限公司 | FAG轴承,苏州FAG轴承,德国FAG轴承-恩梯必传动设备(苏州)有限公司 | 培训中心-海南香蕉蛋糕加盟店技术翰香原中心官网总部 | 超声波焊接机_超音波熔接机_超声波塑焊机十大品牌_塑料超声波焊接设备厂家 | 电梯乘运质量测试仪_电梯安全评估测试仪-武汉懿之刻 | 环氧乙烷灭菌器_压力蒸汽灭菌器_低温等离子过氧化氢灭菌器 _低温蒸汽甲醛灭菌器_清洗工作站_医用干燥柜_灭菌耗材-环氧乙烷灭菌器_脉动真空压力蒸汽灭菌器_低温等离子灭菌设备_河南省三强医疗器械有限责任公司 | 冷藏车厂家|冷藏车价格|小型冷藏车|散装饲料车厂家|程力专用汽车股份有限公司销售十二分公司 | 【官网】博莱特空压机,永磁变频空压机,螺杆空压机-欧能优 | 小型气象站_便携式自动气象站_校园气象站-竞道气象设备网 | 反渗透水处理设备|工业零排放|水厂设备|软化水设备|海南净水设备--海南水处理设备厂家 | 医用空气消毒机-医用管路消毒机-工作服消毒柜-成都三康王 | 紫外线老化试验箱_uv紫外线老化试验箱价格|型号|厂家-正航仪器设备 | 伸缩节_伸缩器_传力接头_伸缩接头_巩义市联通管道厂 | 期货软件-专业期货分析软件下载-云智赢 | 成都亚克力制品,PVC板,双色板雕刻加工,亚克力门牌,亚克力标牌,水晶字雕刻制作-零贰捌广告 | 车牌识别道闸_停车场收费系统_人脸识别考勤机_速通门闸机_充电桩厂家_中全清茂官网 |