在开发移动端页面时,尽可能少使用固定定位布局,由于会在ios系统上引起一系列不可控的情况,好比
1.使用fixed定位的元素会随着页面的滑动而抖动;
2.页面滑动失去惯性;
3.可能在滑动过程当中引起瞬间的页面错乱,中止后恢复正常;
在须要使用fixed定位的时候,就与主体页面分离,保证层级关系,不影响主体页面。
tips:-webkit-overflow-scroll:touch 属性也不能与fixed定位一块儿使用javascript
ios系统下,javascript的日期对象Date( )函数不能识别短横杠:“ - ” ,只能使用斜杠:“ / ”java
// 如下形式 ios能够识别 let date = new Date("2018/09/14"); // 如下形式 ios不能识别 let date = new Date("2018-09-14");
最近维护老项目,使用jquery的on( )写事件委托,安卓下能够点击,ios下不可点击。jquery
// 改方法下ios下点击无效 $("body").on("click", "#first-login .first-login-btn", function () { $("#first-login").hide(); }) //改为touchend事件能够点击 $("body").on("touchend", "#first-login .first-login-btn", function () { $("#first-login").hide(); })
回头查询一下,当使用事件委托给【目标元素】添加 click 事件时,若是【代理元素】是 document或body,而且【目标元素】是默认不可点击的(如 div, span 等),此时click事件会失效。若是【目标元素】是可点击的(好比 button、a 标签),此时click事件仍是有效的。
解决方案能够替换click事件,或者给【目标元素】设置cursor: pointer;ios