jquery 图片缩放拖动的简单实例


Posted in Javascript onJanuary 08, 2014

一、不使用jquery,简单的缩放:

<HTML> 
<HEAD> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<TITLE>onMouseWheel</TITLE> 
<SCRIPT> 
var count = 10; 
function Picture() 
{ 
count = Counting(count); 
Resize(count); 
return false; 
} 
function Counting(count){ 
if (event.wheelDelta >= 120) 
count++; 
else if (event.wheelDelta <= -120) 
count--; 
return count; 
} 
function Resize(count){ 
oImage.style.zoom = count + '0%'; 
oCounter.innerText = count + '0%'; 
} 
</SCRIPT> 
</HEAD> 
<BODY> 
<div align=center> 
<span style="font-weight:bold">Size = 
<span id="oCounter" style="color:red;">100%</span></span> 
<img id="oImage" src="images/aaa.gif" onmousewheel="return Picture();" > 
</div> 
</BODY> 
</HTML>

一、使用jquery,实现缩放和拖动:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title></title>
    <style type="text/css">
        #imgBox
        {
            width: 200px;
            height: 200px;
            background: red;
            overflow: hidden;
            margin: auto;
            position: relative;
        }
        #imgMain
        {
            position: relative;
            top: -200px;
        }
    </style>
    <script src="js/jquery-1.2.6.js" type="text/javascript"></script>
    <script type="text/javascript" language="javascript">
        $(function () {
            var event;
            if ($.browser.mozilla) {
                event = "DOMMouseScroll";
            }
            else {
                event = "mousewheel";
            }
            $("#divBlock").bind(event,
        function (e) {
            var evt = window.event || e;
            var newWidth;
            var newHeight;
            var newLeft;
            var newTop;
            var overHeight = $("#divBlock").height();
            if (evt.detail > 0 || evt.wheelDelta < 0) {
                newWidth = $("#imgMain").width() - 20;
                newHeight = $("#imgMain").height() - 20;
                newLeft = $("#imgMain").position().left + 10;
                newTop = $("#imgMain").position().top + 10 - overHeight;
            }
            else {
                newWidth = $("#imgMain").width() + 20;
                newHeight = $("#imgMain").height() + 20;
                newLeft = $("#imgMain").position().left - 10;
                newTop = $("#imgMain").position().top - 10 - overHeight;
            }
            $("#imgMain").css({ left: newLeft + "px", top: newTop + "px" });
            $("#imgMain").width(newWidth);
            $("#imgMain").height(newHeight);
        }
        );
            $("#divBlock").bind("mousedown", function (e) {
                var xo = e.pageX;
                var yo = e.pageY;
                var imgLeft = $("#imgMain").position().left;
                var imgTop = $("#imgMain").position().top;
                var overHeight = $("#divBlock").height();
                $("#divBlock").bind("mousemove", function (e) {
                    window.getSelection ? window.getSelection().removeAllRanges() : document.selection.empty();
                    var x = e.pageX;
                    var y = e.pageY;
                    var bX = $("#imgBox").offset().left;
                    var bY = $("#imgBox").offset().top;
                    $("#imgMain").css("left", x - bX - (xo - bX) + imgLeft);
                    $("#imgMain").css("top", y - bY - (yo - bY) - overHeight + imgTop);
                });
            });
            $("#divBlock").bind("mouseup mouseout", function () {
                $("#divBlock").unbind("mousemove");
            });
        });
    </script>
</head>
<body>
    <div id="imgBox">
        <div style="width: 200px; height: 200px; cursor: pointer; position: relative; left: 0;
            top: 0; filter: alpha(opacity=0); opacity: 0; -moz-opacity: 0; background: blue;
            z-index: 999;" id="divBlock">
        </div>
        <img src="test.jpg" width="200" height="200" alt="" id="imgMain" />
    </div>
</body>
</html>
Javascript 相关文章推荐
javascript获取当前ip的代码
May 10 Javascript
jQuery contains过滤器实现精确匹配使用方法
Apr 12 Javascript
javascript禁用Tab键脚本实例
Nov 22 Javascript
JS 对java返回的json格式的数据处理方法
Dec 05 Javascript
微信小程序商品详情页规格属性选择示例代码
Oct 30 Javascript
react-native fetch的具体使用方法
Nov 01 Javascript
element-ui表格数据转换的示例代码
Aug 24 Javascript
vue+axios实现文件下载及vue中使用axios的实例
Sep 21 Javascript
浅谈JS的原型和继承
May 08 Javascript
jQuery删除/清空指定元素的所有子节点实例代码
Jul 04 jQuery
ES6 新增的创建数组的方法(小结)
Aug 01 Javascript
在layui.use 中自定义 function 的正确方法
Sep 16 Javascript
document.execCommand()的用法小结
Jan 08 #Javascript
js window.onload 加载多个函数和追加函数详解
Jan 08 #Javascript
js字符串转换成数字与数字转换成字符串的实现方法
Jan 08 #Javascript
JS获取计算机mac地址以及IP的实现方法
Jan 08 #Javascript
JavaScript+CSS控制打印格式示例介绍
Jan 07 #Javascript
jquery实现非叠加式的搜索框提示效果
Jan 07 #Javascript
使用JQUERY进行后台页面布局控制DIV实现左右式
Jan 07 #Javascript
You might like
自己动手,丰衣足食 - 短波框形天线制作
2021/03/01 无线电
使用网络地址转换实现多服务器负载均衡
2006/10/09 PHP
PHP将回调函数作用到给定数组单元的方法
2014/08/19 PHP
php 模拟 asp.net webFrom 按钮提交事件实例
2014/10/13 PHP
PHP动态柱状图实现方法
2015/03/30 PHP
护卫神php套件 php版本升级方法(php5.5.24)
2015/05/10 PHP
PHP身份证校验码计算方法
2016/08/10 PHP
getElementById在任意一款浏览器中都可以用吗的疑问回复
2007/05/13 Javascript
JavaScript基本概念初级讲解论坛贴的学习记录
2009/02/22 Javascript
js取整数、取余数的方法
2014/05/11 Javascript
javascript从image转换为base64位编码的String
2014/07/29 Javascript
JS的数组迭代方法
2015/02/05 Javascript
两种js监听滚轮事件的实现方法
2016/05/13 Javascript
Vuejs第八篇之Vuejs组件的定义实例解析
2016/09/05 Javascript
JavaScript实现时间表动态效果
2017/07/15 Javascript
使用 vue.js 构建大型单页应用
2018/02/10 Javascript
vue中keep-alive的用法及问题描述
2018/05/15 Javascript
Angular7.2.7路由使用初体验
2019/03/01 Javascript
详解如何使用router-link对象方式传递参数?
2019/05/02 Javascript
[01:34:42]NAVI vs EG 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
Python中os和shutil模块实用方法集锦
2014/05/13 Python
Windows8下安装Python的BeautifulSoup
2015/01/22 Python
python实现简易通讯录修改版
2018/03/13 Python
python按时间排序目录下的文件实现方法
2018/10/17 Python
Flask之请求钩子的实现
2018/12/23 Python
python感知机实现代码
2019/01/18 Python
python中安装django模块的方法
2020/03/12 Python
matplotlib运行时配置(Runtime Configuration,rc)参数rcParams解析
2021/01/05 Python
美国打印机墨水和碳粉购物网站:QuikShip Toner
2018/08/29 全球购物
经典c++面试题二
2015/08/14 面试题
如何编写优秀的食品项目创业计划书
2014/01/23 职场文书
公证书样本
2014/04/10 职场文书
个人年终总结开头
2015/03/06 职场文书
导游词之南昌滕王阁
2019/11/29 职场文书
python实现简单的井字棋
2021/05/26 Python
MySQL导致索引失效的几种情况
2022/06/25 MySQL