前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >基于 jQuery支持移动触摸设备的Lightbox插件:Swipebox使用说明

基于 jQuery支持移动触摸设备的Lightbox插件:Swipebox使用说明

作者头像
李维亮
发布2021-07-09 15:27:11
1.6K0
发布2021-07-09 15:27:11
举报
文章被收录于专栏:李维亮的博客李维亮的博客

Swipebox是一款支持桌面、移动触摸手机和平板电脑的jquery Lightbox插件。该lightbox插件支持手机的触摸手势,支持桌面电脑的键盘导航,并且支持视频的播放。

今天介绍一下Swipebox的使用步骤。

先看效果图: 2015101601

简要教程 使用方法 首先在<body>标签之前或<header>标签中引入jquery和swipebox js文件。

代码语言:javascript
复制
<script src="lib/jquery-2.0.3.js"></script>
<script src="src/js/jquery.swipebox.js"></script>

<header>标签中引入swipebox.css文件。

代码语言:javascript
复制
<link rel="stylesheet" href="src/css/swipebox.css">

HTML结构 为超链接标签使用指定的class,使用title属性来指定图片的标题:

代码语言:javascript
复制
<a class="swipebox" title="My Caption" href="big/image.jpg">
<img src="small/image.jpg" alt="image" />
</a>

调用插件 通过.swipebox选择器来绑定该lightbox的swipebox事件:

代码语言:javascript
复制
<script type="text/javascript">// <![CDATA[
;( function( $ ) {

    $( '.swipebox' ).swipebox();

} )( jQuery );
// ]]></script>

高级配置 画廊 你可以在超链接标签中添加一个rel属性来分割画廊图片

代码语言:javascript
复制
<!-- Gallery 1 -->
<a class="swipebox" href="big/image1.jpg" rel="gallery-1">
    <img src="small/image1.jpg" alt="image" />
</a>
<a class="swipebox" href="big/image2.jpg" rel="gallery-1">
    <img src="small/image2.jpg" alt="image" />
</a>
<!-- Gallery 2 -->
<a class="swipebox" href="big/image3.jpg" rel="gallery-2">
    <img src="small/image3.jpg" alt="image" />
</a>
<a class="swipebox" href="big/image4.jpg" rel="gallery-2">
    <img src="small/image4.jpg" alt="image" />
</a>

视频支持 你可以将一个youtube或vimeo的视频URL放到href属性中,该lightbox插件会自动检测它是否是youtube 或 vimeo的视频,并用swipebox打开它。

代码语言:javascript
复制
<a class="swipebox-video" href="http://vimeo.com/29193046" rel="vimeo">My Videos</a>

动态调用画廊 你可以通过一个数组来动态调用你的画廊:

代码语言:javascript
复制
$( '#gallery' ).click( function( e ) {
    e.preventDefault();
    $.swipebox( [
        { href:'big/image1.jpg', title:'My Caption' }, 
        { href:'big/image2.jpg', title:'My Second Caption' }
    ] );
} );

检测状态

代码语言:javascript
复制
if ( $.swipebox.isOpen ) {
    // do stuff
}

可用参数

代码语言:javascript
复制
<script type="text/javascript">// <![CDATA[
    ;( function( $ ) {
 
        $( '.swipebox' ).swipebox( {
            useCSS : true, // false will force the use of jQuery for animations
            useSVG : true, // false to force the use of png for buttons
            initialIndexOnArray : 0, // which image index to init when a array is passed
            hideCloseButtonOnMobile : false, // true will hide the close button on mobile devices
            hideBarsDelay : 3000, // delay before hiding bars on desktop
            videoMaxWidth : 1140, // videos max width
            beforeOpen: function() {}, // called before opening
            afterOpen: null, // called after opening
            afterClose: function() {} // called after closing
            loopAtEnd: false // true will return to the first image after the last image is reached
        } );
 
    } )( jQuery );
// ]]></script>

useCSS:设置为false将强制lightbox使用jQuery来动画。 useSVG:设置为flase将lightbox使用png来制作按钮。 initialIndexOnArray:当lightbox使用数组时使用该参数来设置下标。 hideCloseButtonOnMobile:设置为true时lightbox将在移动设备上隐藏关闭按钮。 hideBarsDelay:lightbox在桌面设备上隐藏信息条的延时时间。 videoMaxWidth:lightbox视频的最大宽度。 beforeOpen:lightbox打开前的回调函数。 afterOpen:lightbox打开后的回调函数。 afterClose:lightbox关闭后的回调函数。 loopAtEnd:设置为true时lightbox将在播放到最后一张图片时接着返回第一张图片播放。 浏览器兼容 Chrome, Safari, Firefox, Opera, IE9+, IOS4+, Android, windows phone.

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2015-10-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档