`
beilejiang
  • 浏览: 6595 次
  • 性别: Icon_minigender_1
  • 来自: 襄樊
社区版块
存档分类
最新评论

javascript+css鼠标悬浮放大图片

阅读更多

仿着淘宝网上面鼠标悬浮图片 放大图片的效果做的,感觉效果还是不太好,希望大家能完善完善!

缺点:放大的图片不像淘宝上面那样清晰,

<script language="JavaScript">
<!--
var srcX = 1024; //原图大小,可以任意设置
var srcY = 768;
var bigX = 200; //预览窗大小,可以任意设置
var bigY = 200;
var smallX = 300; //缩略图宽度
var smallY = srcY * smallX / srcX;
var viewX = bigX / srcX * smallX; //预览范围
var viewY = bigY / srcY * smallY;
var bl = srcX / smallX;//缩小比例
var border = 8; //边框
window.onload=function (){
 head.innerHTML="图片已载入";
 smallpic.width=smallX;
 smallpic.height=smallY;
 bigpic.width=srcX;
 bigpic.height=srcY;
 view.style.width=viewX;
 view.style.height=viewY;
 //smallbox.style.borderWidth=border;
 //bigbox.style.borderWidth=border;
 if (window.event){
  //smallbox.style.width=smallpic.offsetWidth+border*2;
  smallbox.style.width=smallpic.offsetWidth;
  smallbox.style.height=smallpic.offsetHeight;
  //smallbox.style.height=smallpic.offsetHeight+border*2;
  bigbox.style.width=bigX+border*2;
  bigbox.style.height=bigY+border*2;
 }else{
  smallbox.style.width=smallpic.offsetWidth;
  smallbox.style.height=smallpic.offsetHeight;
  bigbox.style.width=bigX;
  bigbox.style.height=bigY;
 }
 move(event);
}
function move(e){
document.getElementById('bigbox').style.visibility="visible";
 var e = window.event?window.event:e;
 var iebug = 0;
 if (window.event){
  var vX = e.offsetX - viewX/2;
  var vY = e.offsetY - viewY/2;
 }else{
  var vX = e.pageX - viewX/2 - smallbox.offsetLeft - border;
  var vY = e.pageY - viewY/2 - smallbox.offsetTop - border;
  iebug = 2;
 }
 if (vX < 0) vX = 0;
 if (vY < 0) vY = 0;
 if (vX > smallX - viewX - iebug) vX = smallX - viewX - iebug;
 if (vY > smallY - viewY - iebug) vY = smallY - viewY - iebug;
 bigpico.style.marginLeft = - vX * bl
 bigpico.style.marginTop = - vY * bl
 view.style.left = vX + smallbox.offsetLeft + border;
 view.style.top = vY + smallbox.offsetTop + border;
}
//-->
</script>
<style type="text/css">
<!--
*{padding:0;margin:0}
img{display:block;}
#smallbox{border:1px #c33 solid;float:left;width:0;height:0;overflow:hidden}
#bigbox{border:1px solid red;width:0px;height:0px;float:left;overflow:hidden}
#view{border:1px #ddd solid;width:0px;height:0px;position:absolute}
#head{text-align:center;line-height:40px;font:bold 16px/40px;color:red}
//-->
</style>
<div id="head">图片loading...</div>
<div id="smallbox" onmouseout="document.getElementById('bigbox').style.visibility='hidden'"><img id="smallpic" src="IVU.jpg" border="0" onmousemove="move(event)"></div>
<div id="bigbox"><div id="bigpico"><img id="bigpic" src="IVU.jpg" border="0"></div></div>
<div id="view" onmousemove="move(event)"></div>

======================

 

分享到:
评论

相关推荐

    jquery鼠标悬浮图片放大效果

    "jQuery鼠标悬浮图片放大效果"就是一个很好的例子,它使得用户在浏览商品图片时能够更清楚地查看细节,从而增强购物体验。这个效果在电商网站如淘宝上广泛使用,今天我们将会详细探讨如何使用jQuery实现这一功能。 ...

    强悍的鼠标悬浮图片特效hover.css

    "强悍的鼠标悬浮图片特效hover.css" 是一个专为图片设计的CSS3特效库,它能为网页中的图片添加各种炫酷的鼠标悬停效果,增强视觉吸引力和交互性。 首先,`hover.css`库是纯CSS3实现的,这意味着它利用了CSS3的新...

    css3鼠标悬浮放大效果 css3鼠标悬浮放大效果网页特效.zip

    在网页设计中,CSS3(层叠样式表第三版)为开发者提供了丰富的视觉效果和交互体验,其中之一就是鼠标悬浮放大效果。这个效果通常用于图片、按钮或其他元素,当用户将鼠标光标悬停在这些元素上时,元素会放大显示,...

    鼠标悬浮 浮动放大 expand 效果

    这个文件名很可能包含了实现鼠标悬浮放大效果的相关资源。压缩包可能包含一个或多个CSS文件(例如`hoverstyle.css`),其中定义了元素的默认样式和`:hover`状态下的样式;可能还有HTML文件(如`index.html`),展示...

    html5 css3透明时钟鼠标悬浮图片放大

    接着,CSS3的`transition`和`transform`属性是实现鼠标悬浮图片放大的关键。`transition`允许元素在不同状态之间平滑过渡,而`transform`则可以改变元素的大小、位置和形状。当鼠标悬停在图片上时,我们可以使用`:...

    模拟京东商城鼠标悬浮图片放大效果代码

    在本文中,我们将深入探讨如何使用JavaScript面向对象编程思想来模拟京东商城的鼠标悬浮图片放大效果。这个功能在电商网站中十分常见,它为用户提供了一种便捷的方式来查看商品的细节,增强购物体验。 首先,我们...

    jQuery鼠标悬浮图片放大特效.zip

    在压缩包中的"jQuery鼠标悬浮图片放大特效"可能包含了示例HTML、CSS和JavaScript文件,供开发者参考和学习。这些文件展示了如何将上述步骤整合到实际项目中,帮助开发者快速理解和应用这一特效。通过查看和分析这些...

    HTML5+CSS3悬浮按钮彩球效果.zip

    悬浮按钮通常由`&lt;button&gt;`元素创建,通过添加特定的类名或ID来标识,以便于CSS3进行样式定义。HTML代码可能会包含如下片段: ```html 悬浮按钮 ``` CSS3则是实现彩球效果的关键。它提供了丰富的样式属性,如动画...

    101web大作业杭州旅游网站共8页 html+jquery+css3 带动画 图片弹窗 鼠标悬浮动画效果

    该压缩包包含了一个基于HTML、jQuery和CSS3的杭州旅游网站项目,总计8个页面,设计上注重用户体验,带有丰富的动画效果,如图片弹窗和鼠标悬浮时的动画。这个项目是一个优秀的学习资源,尤其适合那些正在学习网页...

    jquery css3鼠标悬停图片放大显示效果代码

    "jquery css3鼠标悬停图片放大显示效果代码"是一个典型的技术实现,它结合了JavaScript库jQuery和CSS3的强大功能,为用户创建了一个动态且吸引人的图片展示方式。当用户将鼠标悬停在图片上时,图片会自动放大,突出...

    jquery+css3实现的6种鼠标悬浮图片特效源码.zip

    在本资源中,"jquery+css3实现的6种鼠标悬浮图片特效源码.zip" 提供了一套基于 jQuery 和 CSS3 的图片特效实现,适用于网页设计和开发。这些特效能够为用户带来丰富的交互体验,提升网站的视觉吸引力。以下是关于...

    鼠标悬浮图片放大

    在网页设计中,"鼠标悬浮图片放大"是一种常见的交互效果,它可以增强用户的浏览体验,让细节展示更加清晰。这种效果通常通过JavaScript实现,利用事件监听、CSS变换等技术来完成。接下来,我们将深入探讨如何使用...

    CSS3鼠标经过图片旋转放大代码

    本案例中的“CSS3鼠标经过图片旋转放大代码”就是一个典型的利用CSS3来增强用户体验的例子。它使得用户在鼠标悬停在图片上时,图片不仅会放大,还会伴随旋转效果,为网页增添动态感和互动性。 首先,我们需要了解...

    鼠标悬浮时图片上显示放大图标

    综上所述,"鼠标悬浮时图片上显示放大图标"这一功能的实现涉及了前端开发中的多种技术,包括JavaScript事件监听、CSS样式控制、前端框架的运用以及图片放大效果的实现。开发者可以根据项目的具体需求和技术栈选择...

    jquery+css实现世界地图放大缩小效果.zip

    它通常提供不同国家和地区的SVG或PNG地图数据,并通过jQuery来处理交互事件,如点击、鼠标悬浮等,同时支持缩放和平移。 在提供的HTML文件(index.html、index2.html、index3.html、index4.html)中,可能包含了...

    鼠标悬浮显示放大图标

    在网页设计中,"鼠标悬浮显示放大图标"是一种常见的交互设计技术,主要用于增强用户体验,让用户在不离开当前页面的情况下预览图像的细节。这个功能在电商网站、产品展示页面等场景下尤为常见。通常,当用户将鼠标...

    JS+CSS特效

    本压缩包"JS+CSS特效"包含了四个子文件,分别是jQuery旋转木马特效、jQuery图片放大镜插件制作、CSS3实现的3D图片切换效果以及3D缩略图悬浮效果,这些都是利用JS和CSS构建的典型网页特效。 首先,jQuery旋转木马...

Global site tag (gtag.js) - Google Analytics