smartZoom 是一个我很喜欢用的库。

但是这个库有一些不完善的地方。

比如BUG。

比如使用上可能遇到的问题。

    <article>
<div id="zoom_box" class="zoom-box" style="display: none">
<img>
</div>
</article>

比如说,我们想用 smartZoom 渲染这个img。

前提条件:这个库依赖 jQuery.

首先,它的父元素的宽高必须是个像素值。设 100% 可能会出问题。

可以用 jquery 计算并赋值宽高。

      // 加数字值和项目样式有关 不通用
$("#zoom_box").css({
width: $("article").width() + 40 + 'px',
height: $("article").height() + 25 + 'px',
})

其次。

不要给你想渲染的 img 设宽高。像素值和 100% 什么的都不需要。

最后调用渲染一下就好。

      $("#zoom_box img").smartZoom({
'dblClickEnabled': false,
'containerBackground': "#000"
});

渲染时的参数,github 上有说明。

options = {'top' : '0', // top 像素值 一般用不上
'left' : '0', // left 像素值 一般用不上
'width' : '100%', // 宽度 如果你不希望图片的显示区域是这个DIV全部区域,那么需要设置一下
'height' : '100%', // 高度 同上
'easing' : 'smartZoomEasing', // jquery easing 函数 如果浏览器不支持CSS3 那么需要写一下
'maxScale' : 3, // 最大放大倍率
'dblClickMaxScale' : 1.8, // 双击时的最大放大倍率
'mouseEnabled' : true, // 是否可以用鼠标与渲染区域交互
'scrollEnabled' : true, // 是否可以用滚轮缩放图片
'dblClickEnabled' : true, // 是否可以双击放大图片
'mouseMoveEnabled' : true, // 是否支持鼠标移动交互
'moveCursorEnabled' : true, // 是否可以鼠标拖动图片
'touchEnabled' : true, // 是否支持触摸交互(触摸屏)
'dblTapEnabled' : true, // 是否支持触摸双击(触摸屏)
'pinchEnabled' : true, // enable zoom when user pinch on target
'touchMoveEnabled' : true, // 是否可以通过触摸事件拖动图片
'containerBackground' : '#FFFFFF', // 如果不用样式表,那么可以设置背景色,透明背景需要设为 transparent
'containerClass' : ''// 用的样式表 定制化样式时会用到
}

以上。

2019.08.16 更新

实际上,想给 img 设宽高100%也是可以的。但是DOM结构要改一下。

      <div id="zoom_box" class="zoom-box" style="display: none">
<div id="inner" class="inner">
<img>
</div>
</div>

此时,现在的 div#inner 相当于以前的 img。现在的 img 宽高是 100% ,永远和 div#inner 一样大。

      // inner 的宽度用 inner 的高度和图片比例去计算
$("#inner").css({
width: ($("article").height() + 25) * (1440 / 810) + 'px',
height: ($("article").height() + 25) + 'px',
})

渲染方法也需要改一下。

      $("#zoom_box #inner").smartZoom({
'dblClickEnabled': false,
'containerBackground': "#000"
});

也就是说,以前 smartzoom 渲染绑在 img 上,现在绑在 div#inner 上。

OVER

smartJQueryZoom(smartZoom) 的使用方法的更多相关文章

  1. smartJQueryZoom(smartZoom) 存在的兼容性BUG,以及解决方法

    smartJQueryZoom 是一个很好用的库. 它基于jQuery,可以对某个元素(比如 img)进行渲染,渲染之后可以放大这个区域,在做图片浏览时很好用. 但它有一个兼容性BUG: 当浏览器不是 ...

  2. javaSE27天复习总结

    JAVA学习总结    2 第一天    2 1:计算机概述(了解)    2 (1)计算机    2 (2)计算机硬件    2 (3)计算机软件    2 (4)软件开发(理解)    2 (5) ...

  3. mapreduce多文件输出的两方法

    mapreduce多文件输出的两方法   package duogemap;   import java.io.IOException;   import org.apache.hadoop.conf ...

  4. 【.net 深呼吸】细说CodeDom(6):方法参数

    本文老周就给大伙伴们介绍一下方法参数代码的生成. 在开始之前,先补充一下上一篇烂文的内容.在上一篇文章中,老周检讨了 MemberAttributes 枚举的用法,老周此前误以为该枚举不能进行按位操作 ...

  5. IE6、7下html标签间存在空白符,导致渲染后占用多余空白位置的原因及解决方法

    直接上图:原因:该div包含的内容是靠后台进行print操作,输出的.如果没有输出任何内容,浏览器会默认给该空白区域添加空白符.在IE6.7下,浏览器解析渲染时,会认为空白符也是占位置的,默认其具有字 ...

  6. 多线程爬坑之路-Thread和Runable源码解析之基本方法的运用实例

    前面的文章:多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类) 多线程爬坑之路-Thread和Runable源码解析 前面 ...

  7. [C#] C# 基础回顾 - 匿名方法

    C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ...

  8. ArcGIS 10.0紧凑型切片读写方法

    首先介绍一下ArcGIS10.0的缓存机制: 切片方案 切片方案包括缓存的比例级别.切片尺寸和切片原点.这些属性定义缓存边界的存在位置,在某些客户端中叠加缓存时匹配这些属性十分重要.图像格式和抗锯齿等 ...

  9. [BOT] 一种android中实现“圆角矩形”的方法

    内容简介 文章介绍ImageView(方法也可以应用到其它View)圆角矩形(包括圆形)的一种实现方式,四个角可以分别指定为圆角.思路是利用"Xfermode + Path"来进行 ...

随机推荐

  1. SpringCloud 入门(三)

    前文我们介绍了简单的创建一个客户端,并介绍了它是如何提供服务的,接下来介绍它的另外一个组件:zuul. zuul 提供了微服务的网关功能,通过它提供的接口,可以转发不同的服务,可以当作一个中转站. 搭 ...

  2. SpringCloud 入门(二)

    前文我们介绍了创建注册中心的过程以及配置,接下来我们再简单的创建一个客户端 基本操作和前文一样,不一样的是选择的依赖 然后下一步,修改启动类和配置,结构如下图 修改配置文件application-te ...

  3. APP测试之内存命令查询

    CPU占有率            adb shell dumpsys cpuinfo :获取本机CPU占有率            adb shell dumpsys  cpuinfo | find ...

  4. 实战笔记丨JDBC问题定位指南

    JDBC(Java数据库连接性)是Java API,用于管理与数据库的连接,发出查询和命令以及处理从数据库获得的结果集.JDBC在1997年作为JDK 1.1的一部分发布,是为Java持久层开发的首批 ...

  5. vue全家桶(2.5)

    3.8.动态路由匹配和路由组件传参 3.8.1.动态路由匹配 动态路由意味着不固定,具有某种模式,我们希望通过某种匹配方式,把这种不固定的路由形势映射到同一个组件,例如:一个User组件,不同的ID表 ...

  6. 洛谷 P1196 【银河英雄传说】

    这道题其实就是一个带权并查集的基础题,维护的是点权,所以我们要维护两个数组dis:表示当前点到父亲节点的距离,size:当前子树的大小.那么程序就自然出来了: 代码: #include <bit ...

  7. 安装完kali linux之后要做的10件事——113p.cn

    1.添加国内更新源(可能不是最好的) vim /etc/apt/source.list 科技大学# deb http://mirrors.ustc.edu.cn/kali sana main non- ...

  8. python unittest自动测试框架

    编写函数或者类时进行测试,确保代码正常工作 python  unittest 模块提供了代码测试工具.按照定义测试包括两部分:管理测试依赖库的代码(称为‘固件’)和测试本身. 单元测试用于核实函数的某 ...

  9. HTTPS协议详解(三):PKI 体系

    转自:https://blog.csdn.net/hherima/article/details/52469488 1.RSA身份验证的隐患    身份验证和密钥协商是TLS的基础功能,要求的前提是合 ...

  10. 并发工具CyclicBarrier源码分析及应用

      本文首发于微信公众号[猿灯塔],转载引用请说明出处 今天呢!灯塔君跟大家讲: 并发工具CyclicBarrier源码分析及应用 一.CyclicBarrier简介 1.简介 CyclicBarri ...