JavaScript事件与例子(三)
两个例子,好友选中效果和左侧右侧子菜单
一、好友选中效果
可以通过设置属性的方式判断当前是否被选中,也可以通过获取当前元素的颜色从而得知当前元素状态是否被选中,从而进行操作
1.通过设置属性的方式判断选中的元素
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>好友选中</title> <style> *{ margin:0px auto; padding:0px; } #wai{ height:400px; width:200px; margin-top:100px; margin-left:100px; } .li{ height:30px; width:200px; background-color:blue; border:1px solid white; text-align:center; line-height:30px; vertical-align:middle;} </style> </head> <body> <div id="wai"> <div class="li" ys="0" onmouseover="bian(this)" onclick="xuan(this)" onmouseout="li(this)">风吹柳叶遮黄雀</div> <div class="li" ys="0" onmouseover="bian(this)" onclick="xuan(this)" onmouseout="li(this)">薄翅不觉已落蝉</div> <div class="li" ys="0" onmouseover="bian(this)" onclick="xuan(this)" onmouseout="li(this)">谁将新樽辞旧月</div> <div class="li" ys="0" onmouseover="bian(this)" onclick="xuan(this)" onmouseout="li(this)">今月曾今朝故人</div> </div> </body> </html> <script> //首先获取到所有好友列表 var l=document.getElementsByClassName("li"); //鼠标单击事件 function xuan(b){ //遍历数组,设置属性ys的值为0,颜色为蓝 for(var i=0;i<l.length;i++){ l[i].setAttribute("ys","0"); l[i].style.backgroundColor="blue"; } //当前元素ys属性值为1,颜色为红 b.setAttribute("ys","1"); b.style.backgroundColor="red"; } //鼠标移上的效果 function bian(a){ //遍历数组内容,只要ys属性的值是0,颜色变为蓝色 for(var i=0;i<l.length;i++){ if(l[i].getAttribute("ys")=="0"){ l[i].style.backgroundColor="blue"; } } //获取当前元素ys属性值如为0,则颜色变为绿 if(a.getAttribute("ys")=="0"){ a.style.backgroundColor="green"; } } //鼠标离开事件 function li(c){ //如果当前元素ys值为0,颜色设为蓝色 if(c.getAttribute("ys")=="0"){ c.style.backgroundColor="blue"; } } </script>
2.通过获取当前元素颜色的方式判断
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>好友选中</title> <style> *{ margin:0px auto; } #wai{ margin-top:100px; margin-left:100px; width:300px; height:300px;} .li{ margin:1px; background-color:white; font-family:微软雅黑; font-size:16px; text-align:center; width:300px; height:50px; line-height:50px; vertical-align:middle; float:left;} </style> </head> <body> <div id="wai"> <div class="li" onmouseover="yishang(this)" onclick="dianJi(this)" onmouseout="zou(this)">风吹柳叶遮黄雀</div> <div class="li" onmouseover="yishang(this)" onclick="dianJi(this)" onmouseout="zou(this)">薄翅不觉已落蝉</div> <div class="li" onmouseover="yishang(this)" onclick="dianJi(this)" onmouseout="zou(this)">谁将新樽辞旧月</div> <div class="li" onmouseover="yishang(this)" onclick="dianJi(this)" onmouseout="zou(this)">今月曾经照古人</div> </div> </body> </html> <script> //之前曾经用给每个div加id,然后函数传回id的方式,错误,因为这样函数写在div传回自己的用this,如果函数传回的是下面的div的改变,可以尝试用加div //获取所有列表好友到数组 var z=document.getElementsByClassName('li'); //鼠标移上的效果 function yishang(s){ //遍历数组,判断每个颜色是绿色即移上状态,则颜色设为白色即初始颜色,如果颜色是蓝色即选中状态,则跳出本次循环颜色依旧为蓝色 for(i=0;i<z.length;i++){ if(z[i].style.backgroundColor=="green"){ z[i].style.backgroundColor="white"; }else if(z[i].style.backgroundColor=="blue"){ //跳出本次循环 continue; } //在判断当前元素颜色是否是蓝色即被选中状态,是则跳出即状态不变,否则颜色设为绿色即鼠标移上的效果 if(s.style.backgroundColor=="blue"){ continue; }else{ s.style.backgroundColor="green"; } /* 此方法原本作为对上面方法的优化,可以直接判断现在的颜色如果是白色,则变为绿色,该方法的漏洞在于,当前没有颜色可以获取 如果使用该方法,应当在元素中内联颜色 if(s.style.backgroundColor=="white"){ s.style.backgroundColor="green"; }e*/ } } //鼠标单击事件,鼠标单击首先将所有元素设置为初始白色,然后当前颜色设为蓝色 function dianJi(y){ for(i=0;i<z.length;i++){ z[i].style.backgroundColor="white"; } y.style.backgroundColor="blue"; } //鼠标离开事件,鼠标离开如果颜色是绿色即未被选中,则变为白色 function zou(z){ if(z.style.backgroundColor=="green"){ z.style.backgroundColor="white"; } } </script>
使用这种方法,为何能够获取到当前元素颜色进行判断?首先鼠标移上,执行函数 yishang(),然后进for循环遍历进行判断,不符合判断任何一种情况,则无操作,进行下一个判断,如果当前元素颜色是被选中状态则跳出,如果不是则设为绿色,第一个颜色就这样赋值上了
这个问题我出错的几点需要注意:
1.在函数中,什么时候用数组元素的样式,什么时候用当前元素的样式多次搞错
2.判断中判断样式是否是该颜色,一定要用==
二、左侧右侧子菜单
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>子菜单</title> <style> *{ margin:0px auto; padding:0px;} #wai{ margin-top:150px; margin-left:200px; height:300px; width:100px;} .li{ height:30px; width:100px; background-color:#0FF; line-height:30px; vertical-align:middle; text-align:center; border:1px solid white; } .li1{ height:30px; width:100px; background-color:#0F0; line-height:30px; vertical-align:middle; text-align:center; border:1px solid white; } .li:hover{ background-color:#FF3; } .li1:hover{ background-color:#FF3; } </style> </head> <body> <div id="wai"> <div class="li" onclick="show('cp')">产品中心</div> <div class="liw" id="cp" style="display:none"> <div class="li1">休闲</div> <div class="li1">百货</div> </div> <div class="li" onclick="show('dt')">最新动态</div> <div class="liw" id="dt" style="display:none"> <div class="li1">公司动态</div> <div class="li1">业界新闻</div> </div> <div class="li">关于我们</div> <div class="li">联系我们</div> </div> </body> </html> <script> //单击事件 function show(id){ //获取所有子菜单到数组,获取当前元素 var s=document.getElementsByClassName("liw"); var a=document.getElementById(id); //判断里注意用== //如果当前元素隐藏则显示,否则隐藏 if(a.style.display=="none"){ a.style.display="block"; }else{ a.style.display="none"; } } </script>
JavaScript事件与例子(三)的更多相关文章
- Javascript事件模型(三):JavaScript事件绑定方法总结(及Jquery)
JavaScript中绑定事件的方法主要有三种: 1 在DOM元素中直接绑定 2 JavaScript代码中直接绑定 3 绑定事件监听函数 JQuery中绑定事件的几种方法 主要有on().bind( ...
- JavaScript事件绑定的三种方式
(一)事件绑定的三种方式 (1)通过on的形式 <script type="text/javascript"> var div = document.getElemen ...
- JavaScript事件与例子
事件,就是预先设置好的一段代码,等到用户触发的时候执行. 一:常见的事件: 1.关于鼠标的事件 onclick 鼠标单击触发 ondblclick 鼠标双击触发 onmouseover 鼠标移上触发 ...
- Javascript 事件对象(三)事件冒泡
事件流---事件冒泡取消冒泡:ev.cancelBubble=true ---事件捕获Ie下是没有的,在绑定事件中,标准下是有的 <!DOCTYPE HTML> <html> ...
- JavaScript事件详解-jQuery的事件实现(三)
正文 本文所涉及到的jQuery版本是3.1.1,可以在压缩包中找到event模块.该篇算是阅读笔记,jQuery代码太长.... Dean Edward的addEvent.js 相对于zepto的e ...
- Javascript事件模型系列(一)事件及事件的三种模型
一.开篇 在学习javascript之初,就在网上看过不少介绍javascript事件的文章,毕竟是js基础中的基础,文章零零散散有不少,但遗憾的是没有看到比较全面的系列文章.犹记得去年这个时候,参加 ...
- javascript系列之DOM(三)---事件
原文:javascript系列之DOM(三)---事件 事件是javascript跳动的心脏,是DOM所有成分结合的万金油.当我们在WEB 上进行某些交互时,事件也就发生了.点击某些内容,鼠标经过特定 ...
- c#封装DBHelper类 c# 图片加水印 (摘)C#生成随机数的三种方法 使用LINQ、Lambda 表达式 、委托快速比较两个集合,找出需要新增、修改、删除的对象 c# 制作正方形图片 JavaScript 事件循环及异步原理(完全指北)
c#封装DBHelper类 public enum EffentNextType { /// <summary> /// 对其他语句无任何影响 /// </summary> ...
- javaScript事件(三)事件对象
一.事件 二.事件流 以上内容见:javaScript事件(一)事件流 三.事件处理程序 四.IE事件处理程序 以上内容见javaScript事件(二)事件处理程序 五.事件对象 1.认识事件对象 事 ...
随机推荐
- Gym - 101102C线段树
Judge Bahosain was bored at ACM AmrahCPC 2016 as the winner of the contest had the first rank from t ...
- Could not find a valid gem 'compass' (>= 0) in any repository compass安装失败解决方案
安装完成ruby gem 之后,通过 gem install compass 安装compass~~ 出现如下报错 Could not find a valid gem 'compass' (> ...
- 微软Build 2017第二天 .NET Standard 2.0 Preview 的客户端跨平台
微软公司一年一度的开发者大会,即“Microsoft Build 2017”在总部西雅图正式开幕.按照官方安排,本次大会将持续 3 天,主题围绕微软公司各项最新技术成果的展示和研讨,包括与微软相关的产 ...
- EntityFramework中出现DateTime2异常的完美解决办法
今天在使用entityframework往数据库插入数据的时候,突然出现了一个数据类型转换异常的问题: System.Data.SqlClient.SqlException: 从 datetime2 ...
- java之 Timer 类的使用以及深入理解
最近一直在看线程知识,然后看到Timer定时器使用了线程实现的定时功能,于是了解了解: 本文 从Time类的使用和源码分析两个方面讲解: 1---Timer类使用 2---源码分析 1.Time类使用 ...
- 前端小课堂 js:函数的创建方式及区别
js 函数的创建大体有这几种方式: -1-函数表达式(函数字面量): 说白了就是把一个函数赋值给了一个变量. var fun1 = function(index){ alert(index); } f ...
- 二、 添加控制器Controller(ASP.NET MVC5 系列)
MVC是Model-View-Controller的简写.MVC是一种开发良好架构,可测试,易维护应用程序的设计模式.据于MVC的应用程序应该包含: Models: 是呈现应用程序数据和使用验证逻辑给 ...
- unity 在安卓个IOS平台上 同一个按钮 点击后实现不同的功能
#if UNITY_IOS UIEventListener.Get(mSprites["Recharge"].gameObject).onClick = OnIOSRecharge ...
- MyBatis双数据源配置
配置相关 jdbc 配置 #============================================================================ # MySQL # ...
- 挂载mount
mount 1 挂载mount 基本概念 挂载:将额外文件系统与根文件系统现存的目录建立起关联关系,进而使得此目录做为其它文件访问入库的行为 卸载:为解除关联关系的过程 注意:挂载点下原有的文件在挂载 ...