html鼠标滚动图片放大缩小,基于jquery的鼠标滚动放大缩小图片

一直以来都想写一个图片放大和缩小的小玩意,本来以为会很复杂,这几天自己思考了一下,原来是so easy啊。目前实现的放大缩小,主要时依据鼠标的滚轮触发事件来实现的,废话少说直接上源码。

图片放大缩小

*{

margin:0; padding:0;

}

body {

width:100%; height:100%; overflow:auto;

}

#img {

display:block;

width:20%;

margin:20px auto;

cursor:-webkit-zoom-in;

cursor:-moz-zoom-in;

border:4px solid #ccc;

}

$(document).ready(function(){

var img=$("#img");

var i=0;

img.bind('DOMMouseScroll mousewheel function(e) {

var ev=window.event||e;//处理浏览器兼容性问题

var scrollUnit=Math.max(-1,Math.min(1,(ev.wheelDelta||-ev.detail)));

var newWith=Math.max(100,Math.min(1600,parseInt(img.css("width"))+(30*scrollUnit)))+"px";

img.css("width",newWith);

console.log(i++);

console.log(img.css("width"));

});

});

drag.jpg

针对源码,做几点说明和补充:

1,ev.wheelDelta和ev.detail

ev.wheelDelta, 除出火狐外的浏览器IE,chrome,Opera、Safari基本支持属性,该属性取值为+,-,120;

ev.detail,为火狐特有的事件属性,取值+,-3;

2,Math.min,Math.max

这个地方的取最大值和最小值,最好自己琢磨一下,稍微有一个绕。

3,放大缩小的倍数和最值问题

1和-1控制缩小和放大速率,绝对值越大缩放效果越明显。

100,1600,分别为缩小的最小值和放大的最大值。

基本就这么多了,欢迎大家提出宝贵建议和想法。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值