下载最新版的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
改成
var round = function (round) { return round; };