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

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

创新互联专注于文水企业网站建设,成都响应式网站建设公司,成都商城网站开发。文水网站建设公司,为文水等地区提供建站服务。全流程定制开发,专业设计,全程项目跟踪,创新互联专业和态度为您提供的服务

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>图片放大缩小</title>

<style type="text/css">

*{

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; 

}

</style>

<script src="./jquery/jquery-1.8.3.min.js"></script>   

<script type="text/javascript">

$(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"));

  });

});

</script>

</head>

<body>

<img id="img" src="p_w_picpaths/drag.jpg"/>

</body>

</html>

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

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,分别为缩小的最小值和放大的最大值。

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

本文标题:基于jquery的鼠标滚动放大缩小图片
当前网址:https://www.cdcxhl.com/article32/ihgcsc.html

成都网站建设公司_创新互联,为您提供手机网站建设微信小程序网站改版定制网站网站营销微信公众号

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

绵阳服务器托管