前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >动态实现指定图片半透明及鼠标事件

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

作者头像
小李刀刀
发布2018-03-02 14:55:24
1.2K0
发布2018-03-02 14:55:24
举报
文章被收录于专栏:PHP 开发

说明:在不改变HTML代码的前提下,通过CSS和JavaScript,对指定的图片实现半透明效果。并为该图片添加鼠标滑过和滑出特效。

具体实现:

1.假设我们要操作的图片放置在一个id="imgbox"的div容器中。如下面的代码:

代码语言:js
复制
<div id="imgbox" style="width:700px;margin:auto;"><img src="/images/logof.gif"></div>

2.首先,在css中增加两个类定义,为了避免影响到其它图片,最好是用选择限定符加以限定。如下代码:

代码语言:js
复制
#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将在页面载入完成之后,为我们指定的图片添加半透明效果和鼠标事件:

代码语言:js
复制
<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属性的时候,同时使用了两种方式:

代码语言:js
复制
imgNode.setAttribute("class","low");
imgNode.className = "low";

第一种方式是针对IE以外的浏览器,按理说设置class属性对所有的浏览器都是有效的。但是IE比较有个性,它通过元素的className来定义class属性。这是IE不符合规范的地方,但是我们不得不考虑到IE占据的广大市场。所以,同时使用两种方式,从而达到跨浏览器兼容的效果。

适合多图片调用的修改

当时做的时候是针对单张图片的情况做的。如果要用于调用的多图片,可以把JS代码做如下修改:

代码语言: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>

再做改进:改为当图片加载完毕就产生效果:

首先定义函数:

代码语言:js
复制
<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>

然后在图片调用代码的后面调用此函数(例如):

代码语言:js
复制
<div id="imgbox" style="width:700px;margin:auto;"><img src="/images/logof.gif"></div>
<script type="text/javascript" language="JavaScript">transpic();</script>
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2006-04-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档