jQuery滚动插件Sly.js 滑动最后几个元素不在一行 滑动显示不完整
2017-08-31 15:04
302 查看
下载最新版的sly:http://darsa.in/sly/
移动端需要做适配,一行要求恰好显示10个li,总计是12个,因为是适配的问题,所以li的宽度就不能写死
最初的解决方案是是每个长度是总宽度是10%
css的写法
width:10%
发现差了几个像素导致后面的li直接被挤到下行去了,直接的后果就是看不到最后面的元素
后来用js直接算写成px
var width = (($("#list").width() - 10)/10);
document.write("<style>" +
"li{width:"+width+"px}"+
"</style>")
因为每个li有个右边框所以总宽度得去除10个像素
结果发现问题还是没解决
后来在css里面直接写
width:40px;
这样就没问题
慢慢的发现了一个规律,就是只要宽度是带小数点的就不行,整数就没问题
后来查找源码,原来
li的parent就是ul的宽度是round四舍五入出来的,而且插件里面用了大量的四舍五入,对于整数不存在误差,而小数随着累计误差就越来越大
对于sly1.6.1 链接:https://raw.githubusercontent.com/darsain/sly/master/dist/sly.js
来说,在line39
只需要把系统默认的round方法去掉就ok,把
var round = nMath.round
改成
经测试问题搞定!这是插件的一个坑!
移动端需要做适配,一行要求恰好显示10个li,总计是12个,因为是适配的问题,所以li的宽度就不能写死
最初的解决方案是是每个长度是总宽度是10%
css的写法
width:10%
发现差了几个像素导致后面的li直接被挤到下行去了,直接的后果就是看不到最后面的元素
后来用js直接算写成px
var width = (($("#list").width() - 10)/10);
document.write("<style>" +
"li{width:"+width+"px}"+
"</style>")
因为每个li有个右边框所以总宽度得去除10个像素
结果发现问题还是没解决
后来在css里面直接写
width:40px;
这样就没问题
慢慢的发现了一个规律,就是只要宽度是带小数点的就不行,整数就没问题
后来查找源码,原来
li的parent就是ul的宽度是round四舍五入出来的,而且插件里面用了大量的四舍五入,对于整数不存在误差,而小数随着累计误差就越来越大
对于sly1.6.1 链接:https://raw.githubusercontent.com/darsain/sly/master/dist/sly.js
来说,在line39
只需要把系统默认的round方法去掉就ok,把
var round = nMath.round
改成
var round = function (round) { return round; };
经测试问题搞定!这是插件的一个坑!
相关文章推荐
- 页面滚动图片等元素动态加载插件jquery.scrollLoading.js
- 页面滚动显示或隐藏元素Headroom.js插件帮助你实现滚动效果
- jQuery全屏滚动插件fullPage.js使用中遇到的问题(滑动轮播效果无效)
- JQuery插件Marquee.js实现无缝滚动效果
- android GridView最后一行显示不完整解决办法
- 基于特定值来判断隐藏显示元素的jQuery插件
- 第31款插件:第26款插件:jcarousellite.js 基于Jquery的无缝“水平滚动”图片插件
- jQuery-全屏滚动插件【fullPage.js】API 使用方法总结
- 一个很好玩的jquery例子:小方块先逐渐显示,后向右滑动,再向左滑回,最后向上隐藏
- JS加jquery简单实现标签元素的显示或隐藏
- hwSlider-内容滑动切换效果(三):jquery.hwSlide.js插件封装
- 安卓自定义控件之仅可以显示一行视图的view控件(类似 HorizontalScrollView但不可滑动一行排满不在排)
- JS实现随页面滚动显示/隐藏窗口固定位置元素
- JS加jquery简单实现标签元素的显示或隐藏
- jQuery控制元素显示、隐藏、切换、滑动的方法
- [jQuery插件] Sly:灵活的基于ITEM的滚动插件
- 帮助更语义化的显示时间的jQuery插件 - tidyTime.js
- aos.js超赞页面滚动元素动画jQuery动画库
- 简单的图片滑动效果插件 jQuery.iocnSlider.js
- 第32款插件:第26款插件:jcarousellite.js 基于Jquery的无缝“垂直滚动”图片插件