如何在lightbox中添加鼠标滚轮缩放和Base64图像支持

如何在lightbox中添加鼠标滚轮缩放和Base64图像支持

 

LightBox2是的Jquery插件之一。配置的细节就不讲了,但今天我要和你们分享如何用鼠标滚轮放大和缩小大图,

1、修改Lightbox源码使支持滚轮缩放

 

支持鼠标滚轮主要就是把弹出后的框整个绑定上mousewheel事件,打开lightbox.js,找到Lightbox.prototype.build = function() {…}这一段,可以在这里(lightbox初始化的时候)把想要的滚轮事件绑定上去,比如在函数的末尾添加如下代码:

 

// 图片滚轮缩放

this.img = this.$container.find(‘.lb-image’);

this.label = this.$lightbox.find(‘.lb-dataContainer’);

$([this.$overlay[0],this.$lightbox[0]]).bind(“mousewheel”, function(e){

var flag= e.originalEvent.wheelDelta < 0;

var imgH = self.img.height();

var imgW = self.img.width();

var nw = Math.round(20*imgW/imgH);

var ctH = self.$outerContainer.height();

var ctW = self.$outerContainer.width();

var layH = self.$overlay.height()-20;

var layW = self.$overlay.width()-20;

// 向下

if(flag && imgH>20 && imgW>20) {

self.img.css(‘height’, imgH – 20);

self.img.css(‘width’, imgW – nw);

self.$outerContainer.css(‘height’, ctH – 20);

self.$outerContainer.css(‘width’, ctW – nw);

if(ctW-nw > 240){

self.label.css(‘width’, ctW – nw);

}

} else if(!flag && imgH<layH && imgW<layW) {

self.img.css(‘height’, imgH + 20);

self.img.css(‘width’, imgW + nw);

self.$outerContainer.css(‘height’, ctH + 20);

self.$outerContainer.css(‘width’, ctW + nw);

self.label.css(‘width’, ctW + nw);

}

e.stopPropagation();

return false;

});

 

代码比较好理解,就是给后面背景和前面图片都添加鼠标滚轮监听,然后高、宽成比例地缩放(向上滚放大、向下滚缩小),我是设定每次高度变化为20个像素,然后宽度是成比例变化。需要注意的地方,应该是在图片的最小缩小大小,和图片放大不能超过屏幕范围的限制。同时,为了更好的体验,一定要加上e.stopPropagation(),且返回false,让浏览器不要滚动。

 

2、修改Lightbox源码使支持Base64图片

 

这里说起来可能比较麻烦,先来看一下在使用原生Lightbox时的html代码格式要求:

 

<a href=”img/image.jpg” rel=”external nofollow” data-lightbox=”test”>Image #1</a>

 

这是一个最简单的弹出图,当点击Image #1时,就会弹出一个lightbox显示img/image.jpg的内容(弹出一个元素<img src=”img/image.jpg” />)。

现在我们来考虑这种情况,如果图片是以Base64编码在服务器是存放在数据库中的?应该就是这样:

 

<a href=”data:image/png;base64,iVBORw…” rel=”external nofollow” rel=”external nofollow” data-lightbox=”test”>Image #1</a>

 

问题来了,href长度在IE下是有限制的,一张大的图片,不可能放在href字段中,图片将会被阉割(只显示上半部分)。

另外还有一种普遍情况,如果我是先显示小图,点击小图看大图,应该就是这样:

 

<a href=”data:image/png;base64,iVBORw…” rel=”external nofollow” rel=”external nofollow” data-lightbox=”test”>

<img src=”data:image/png;base64,iVBORw…” />

</a>

 

好了,这有两份重复的base64数据,而且都是从服务器端传过来的,耗时耗带宽啊。

所以我按我的需求进行了改造,代码很简单,修改Lightbox.prototype.start = function($link) {…} 中的子函数addToAlbum:

 

function addToAlbum($link) {

self.album.push({

// link: $link.attr(‘href’),

link: $link.children().attr(“src”),

title: $link.attr(‘data-title’) || $link.attr(‘title’)

});

}

 

注释掉的部分就是原来的,$link是前面HTML代码中的a标签,改过后addToAlbum函数的作用是:在设置弹出图片的src时,不再从原始的的href中取字符作为弹出img标签的src,而是直接从a标签的子元素中找src属性,由于src属性的长度无限制,所以它不会存在图片截断的问题。

 

3、将Lightbox应用到已有的文章

 

第2节已经讲到了Lightbox使用时HTML有一定的格式,如果已有的文章中的图片是<img src=”img/image.jpg”>这样的,则必须对其进行一层封装:

 

function initLightbox(){

var imgs = $(“.lightbox-container”).find(‘img’);

$.each(imgs,function(i) {

var img = $(imgs[i]);

img.wrap(“<a href=” data-lightbox=’test’ ></a>”);

});

}

 

其中,“lightbox-container”是文章所在容器的class。initLightbox函数应放置在页面加载ready时,它会把文章中的所有img标签都封装成为lightbox的格式。

 

本文就写到这了,第2、3点大家可以看自己的使用场景去使用,lightbox改动的重点在于支持滚轮缩放。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/115268.html<

(0)
运维的头像运维
上一篇2025-02-18 01:27
下一篇 2025-02-18 01:28

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注