移动端单页视图库,适用于制作移动专题
http://jsbin.com/vatuma/latest
手机扫描下面二维码查看例子:
首先,页面必须是下面的结构
<html>
// ...
<body>
<div id="touchBoxCt">
<div>
// 子视图1
</div>
<div>
// 子视图2
</div>
<div>
// 子视图3
</div>
</div>
</body>
</html>
初始CSS,除以下两个样式之外,TouchBox不依赖任何其他样式
/* 如果不将body的margin设为0,会导致视图高宽计算不准确 */
body, div {
margin: 0;
padding: 0;
}
/* 默认将子视图隐藏,防止首屏显示页面闪动,TouchBox初始化默认切到第一个视图 */
#touchBoxCt>div{
display: none;
}
new TouchBox('#touchBoxCt', {
loop: true,
animation: 'flow'
});
子视图选择器,默认'',如果设置,则使用选择器选中的子元素进行视图切换
首视图索引,默认0,默认为第一个子元素
子视图切换是否可以循环切换,默认false
视图切换的动画效果,默认'flow',取值范围:'slide'、'flow'
视图切换动画时间,默认400,单位ms
锁屏状态,默认'off',取值:
- 'off' 不锁屏
- 'landscape' 锁定为横屏
- 'portrait' 锁定为竖屏
锁屏提示,当lockScreen不为'off'时有效。
当值为String时,HTML字符串会被插入到页面并显示。
当值为Function时,函数的返回值会被被插入到页面并显示。
子视图开始切换时回调函数,如果返回值为false,则终止当次切换操作。
回调函数参数:
- toIndex 切换到视图索引
- active 当前视图索引
子视图切换结束时回调函数
回调函数参数:
- active 当前视图索引
当TouchBox高宽被重置时调用。
回调函数参数:
- width 高度
- height 宽度
回调函数的作用域
回调函数事件监听方法:
boxer.on('beforeslide', function(toIndex, activeIndex) {
console.log('beforeslide, ', 'to index:', toIndex, ' current index:', activeIndex);
});
touchstart事件,返回false则中止本次touch动作。
回调函数参数:
- active 当前视图索引
touchmove事件,返回false则中止视图偏移。
回调函数参数:
- active 当前视图索引
- offsetY Y轴位置偏移量,大于0表示手指向上移动,小于0表示手指向下移动
touchend事件,返回false则中止视图切换,将视图重置为当前视图。
回调函数参数:
- active 当前视图索引
- offsetY Y轴位置偏移量,大于0表示手指向上移动,小于0表示手指向下移动
子视图开始切换时回调函数,如果返回值为false,则终止当次切换操作。
回调函数参数:
- toIndex 切换到视图索引
- active 当前视图索引
子视图切换结束时回调函数
回调函数参数:
- active 当前视图索引
当TouchBox高宽被重置时调用
回调函数参数:
- width 高度
- height 宽度