专栏首页PHP 开发动态实现指定图片半透明及鼠标事件

动态实现指定图片半透明及鼠标事件

说明:在不改变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>

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Spiral 详细上手指南之请求和响应

    在上一篇《Spiral 详细上手指南之路由规则》中,相信大家对于 Spiral 框架中的路由配置已经完全掌握了。不过在文章结束的时候,我们创建的控制器针对各种请...

    小李刀刀
  • Laravel 5.5 为响应请求提供的可响应接口

    Laravel 5.5 的路由中增加了一种新的返回类型:可相应接口(Responsable)。该接口允许对象在从控制器或者闭包路由中返回时自动被转化为标准的 H...

    小李刀刀
  • Spiral 官方超完整实战教程

    我在写“Spiral 详细上手指南”的过程其实是一边做官方文档的翻译,一边验证英文版教程中内容的正确性,一边写的。而且涉及到每一个模块和组件,除了在演示项目中简...

    小李刀刀
  • HTTP Strict Transport Security实战详解

    HTTP Strict Transport Security (通常简称为HSTS) 是一个安全功能,它告诉浏览器只能通过HTTPS访问当前资源, 禁止HTTP...

    sunsky
  • Unity入门教程(上)

    Zoctopus
  • 一个远古但是有效的推广方案(CS)

    很久以前LOC就有大佬说自己通过植入链接。获取了数百的返利。一直以为那个大佬是吹牛的。(毕竟LOC吹牛大佬多了去)。直到今天发现某大佬的博客有条神秘代码。查看了...

    用户1191760
  • RocketMQ学习-NameServer-2

    上篇文章主要梳理了NameServer的启动器和配置信息,并复习了JVM中的关闭钩子这个知识点。这篇文章看下NameServer的其他模块。建议带着如下三个问题...

    阿杜
  • xwiki开发者指南-执行异步任务

    这操作可能需要大量的时间,所以我们需要显示进度。这意味着我们不能阻塞触发操作的HTTP请求。换句话说,操作应该是异步的。

    lilihongjava
  • MyBatis源码解析之基础模块—TypeHandler

    上一章节我们一起分析了Mybatis的Plugin模块的源码。掌握了如何配置拦截器注解,如何自定义拦截器以及拦截器的执行过程。

    todobugs
  • 聊聊hikari连接池的fixed pool design

    HikariCP-2.7.6-sources.jar!/com/zaxxer/hikari/pool/HikariPool.java

    codecraft

扫码关注云+社区

领取腾讯云代金券