html图片滚轮缩放,JS滚轮控制图片缩放大小和拖动的实例代码

JS滚轮控制图片缩放大小和拖动的实例代码

发布时间:2020-10-26 07:40:32

来源:脚本之家

阅读:91

作者:小角色Byme

具体代码如下所示:

Document

.dragAble {

position: relative;

cursor: move;

}

.img-con {

position: relative;

width: 713px;

height: 455px;

overflow: hidden;

border: 1px solid red;

}

sy_20110714135215645030.jpg

window.onload = function() {

var oImg = document.getElementsByTagName("img")[0];

function fnWheel(obj, fncc) {

obj.onmousewheel = fn;

if (obj.addEventListener) {

obj.addEventListener('DOMMouseScroll', fn, false);

}

function fn(ev) {

var oEvent = ev || window.event;

var down = true;

if (oEvent.detail) {

down = oEvent.detail > 0

} else {

down = oEvent.wheelDelta < 0

}

if (fncc) {

fncc.call(this, down, oEvent);

}

if (oEvent.preventDefault) {

oEvent.preventDefault();

}

return false;

}

};

fnWheel(oImg, function(down, oEvent) {

var oldWidth = this.offsetWidth;

var oldHeight = this.offsetHeight;

var oldLeft = this.offsetLeft;

var oldTop = this.offsetTop;

var scaleX = (oEvent.clientX - oldLeft) / oldWidth; //比例

var scaleY = (oEvent.clientY - oldTop) / oldHeight;

if (down) {

this.style.width = this.offsetWidth * 0.9 + "px";

this.style.height = this.offsetHeight * 0.9 + "px";

} else {

this.style.width = this.offsetWidth * 1.1 + "px";

this.style.height = this.offsetHeight * 1.1 + "px";

}

var newWidth = this.offsetWidth;

var newHeight = this.offsetHeight;

this.style.left = oldLeft - scaleX * (newWidth - oldWidth) + "px";

this.style.top = oldTop - scaleY * (newHeight - oldHeight) + "px";

});

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值