动态实现指定图片半透明及鼠标事件
时间:2022-05-02
本文章向大家介绍动态实现指定图片半透明及鼠标事件,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
说明:在不改变HTML代码的前提下,通过CSS和JavaScript,对指定的图片实现半透明效果。并为该图片添加鼠标滑过和滑出特效。
具体实现:
1.假设我们要操作的图片放置在一个id="imgbox"的div容器中。如下面的代码:
<div id="imgbox" style="width:700px;margin:auto;"><img src="/images/logof.gif"></div>
2.首先,在css中增加两个类定义,为了避免影响到其它图片,最好是用选择限定符加以限定。如下代码:
#imgbox img.low{-moz-opacity:0.5;filter:alpha(opacity=50);cursor:hand;}
#imgbox img.high{-moz-opacity:1;filter:alpha(opacity=100);cursor:hand;}
3.然后在网页的<head>区域增加JavaScript,JavaScript将在页面载入完成之后,为我们指定的图片添加半透明效果和鼠标事件:
<script language="JavaScript" type="text/javascript">
window.onload = function() {
var imgNode = document.getElementById("imgbox").getElementsByTagName("img")[0];
imgNode.setAttribute("class","low");
imgNode.className = "low";
imgNode.onmouseover = function(){
this.setAttribute("class","high");
this.className = "high";
}
imgNode.onmouseout = function(){
this.setAttribute("class","low");
this.className = "low";
}
}
</script>
补充说明:
在上面的JavaScript中,设置图片的class属性的时候,同时使用了两种方式:
imgNode.setAttribute("class","low");
imgNode.className = "low";
第一种方式是针对IE以外的浏览器,按理说设置class属性对所有的浏览器都是有效的。但是IE比较有个性,它通过元素的className来定义class属性。这是IE不符合规范的地方,但是我们不得不考虑到IE占据的广大市场。所以,同时使用两种方式,从而达到跨浏览器兼容的效果。
适合多图片调用的修改
当时做的时候是针对单张图片的情况做的。如果要用于调用的多图片,可以把JS代码做如下修改:
<script language="JavaScript" type="text/javascript">
window.onload = function() {
var imgNodes = document.getElementById("imgbox").getElementsByTagName("img");
for (var i=0; i<imgNodes.length; i++ ){
var imgNode = imgNodes;
imgNode.setAttribute("class","low");
imgNode.className = "low";
imgNode.onmouseover = function(){
this.setAttribute("class","high");
this.className = "high";
}
imgNode.onmouseout = function(){
this.setAttribute("class","low");
this.className = "low";
}
}
}
</script>
再做改进:改为当图片加载完毕就产生效果:
首先定义函数:
<script language="JavaScript" type="text/javascript">
function transpic() {
var imgNodes = document.getElementById("imgbox").getElementsByTagName("img");
for (var i=0; i<imgNodes.length; i++ ){
var imgNode = imgNodes;
imgNode.setAttribute("class","low");
imgNode.className = "low";
imgNode.onmouseover = function(){
this.setAttribute("class","high");
this.className = "high";
}
imgNode.onmouseout = function(){
this.setAttribute("class","low");
this.className = "low";
}
}
}
</script>
然后在图片调用代码的后面调用此函数(例如):
<div id="imgbox" style="width:700px;margin:auto;"><img src="/images/logof.gif"></div>
<script type="text/javascript" language="JavaScript">transpic();</script>
- Golang 连接mssql sql server
- UWP基础教程 - XAML对象元素和属性
- UWP基础教程 - 禁用&开启截取应用屏幕
- Android开发中应该避免的内存泄露
- UWP基础教程 - XAML资源
- Golang笔记——并发
- UWP基础教程 - XAML标记扩展
- UWP基础教程 - RelativePanel
- UWP基础教程 - AuotmationProperties.Name
- 暴力遍历还没注册的双拼域名
- JRuby——Java和Ruby的强强联合
- Golang语言关于零值的定义
- 使用Yeoman创建ASP.NET Core项目
- Golang语言捕获panic异常并转化为error
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 浙大版《C语言程序设计(第3版)》题目集 练习5-2 找两个数中最大者
- 浙大版《C语言程序设计(第3版)》题目集 练习5-3 数字金字塔
- 浙大版《C语言程序设计(第3版)》题目集 习题5-1 符号函数
- 浙大版《C语言程序设计(第3版)》题目集 习题5-2 使用函数求奇数和
- 浙大版《C语言程序设计(第3版)》题目集 习题5-3 使用函数计算两点间的距离
- 浙大版《C语言程序设计(第3版)》题目集 习题5-4 使用函数求素数和
- Linux进程之如何查看进程详情?
- 浙大版《C语言程序设计(第3版)》题目集 习题5-5 使用函数统计指定数字的个数
- 浙大版《C语言程序设计(第3版)》题目集 习题5-6 使用函数输出水仙花数
- 浙大版《C语言程序设计(第3版)》题目集 习题5-7 使用函数求余弦函数的近似值
- 浙大版《C语言程序设计(第3版)》题目集 习题6-1 分类统计字符个数
- 微信群总是有人发广告?看我用Python写一个自动化机器人消灭他!
- 浙大版《C语言程序设计(第3版)》题目集 习题6-2 使用函数求特殊a串数列和
- 浙大版《C语言程序设计(第3版)》题目集 习题6-4 使用函数输出指定范围内的Fibonacci数
- 浙大版《C语言程序设计(第3版)》题目集 习题6-5 使用函数验证哥德巴赫猜想