Web移动端开发技巧总结

标签: 移动端 分类: Javascript 创建时间:2019-04-25 02:20:40 更新时间:2024-11-15 10:49:44

在我们日常的开发中,成为全栈开发,已经是一个前端程序员不得不修行的一门功课了。刚刚脱离了IE678的束缚,现如今又必须兼容移动端。移动端又分为Android和IOS,主要以谷歌浏览器、Safari、火狐浏览器为主,还包括国内的各种套壳浏览器,那就不可胜数了,UC浏览器、百度、小米、华为、360浏览器…

1.禁止蒙层底部页面跟随滚动

这个问题出现的场景主要是,在页面的弹出层中进行鼠标滚动,弹出层下方的滚动条会跟随滚动。这又分为两种情况,一种是弹出层本身没有滚动条,这种情况比较简单,只需要在弹出层出现时将底下的body设置为overflow:hidden即可; 另一种情况是弹出层本身自带滚动条,在弹出层出现的时候,除了设置底下的body外,为了更好的兼容性,还需要做移动端Safari的特别处理。经过测试,将页面固定在视窗(positon:fixed),然后记录滚动位置,关闭弹出层之后在恢复其滚动位置,我觉得这种方式更加的通用和简洁。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
let bodyEl = document.body
let top = 0

function stopBodyScroll (isFixed) {
if (isFixed) {
top = window.scrollY

bodyEl.style.position = 'fixed'
bodyEl.style.top = -top + 'px'
} else {
bodyEl.style.position = ''
bodyEl.style.top = ''

window.scrollTo(0, top) // 回到原先的top
}
}
参考文章:
1.禁止蒙层底部页面跟随滚动:https://segmentfault.com/a/1190000012313337
2.弹出弹窗后,如何禁止底层的body滚动,适用于超长的页面(2018.11更新):https://blog.csdn.net/github_36487770/article/details/78971761
3.弹出层完美禁止页面滚动:https://codepen.io/zhaojun/post/forbidscroll
4.web移动端浮层滚动阻止window窗体滚动JS/CSS处理:https://www.zhangxinxu.com/wordpress/2016/12/web-mobile-scroll-prevent-window-js-css/
小额赞助
本人提供免费与付费咨询服务,感谢您的支持!赞助请发邮件通知,方便公布您的善意!
**光 3.01 元
Sun 3.00 元
bibichuan 3.00 元
微信公众号
广告位
诚心邀请广大金主爸爸洽谈合作
每日一省
isNaN 和 Number.isNaN 函数的区别?

1.函数 isNaN 接收参数后,会尝试将这个参数转换为数值,任何不能被转换为数值的的值都会返回 true,因此非数字值传入也会返回 true ,会影响 NaN 的判断。

2.函数 Number.isNaN 会首先判断传入参数是否为数字,如果是数字再继续判断是否为 NaN ,不会进行数据类型的转换,这种方法对于 NaN 的判断更为准确。

每日二省
为什么0.1+0.2 ! == 0.3,如何让其相等?

一个直接的解决方法就是设置一个误差范围,通常称为“机器精度”。对JavaScript来说,这个值通常为2-52,在ES6中,提供了Number.EPSILON属性,而它的值就是2-52,只要判断0.1+0.2-0.3是否小于Number.EPSILON,如果小于,就可以判断为0.1+0.2 ===0.3。

每日三省
== 操作符的强制类型转换规则?

1.首先会判断两者类型是否**相同,**相同的话就比较两者的大小。

2.类型不相同的话,就会进行类型转换。

3.会先判断是否在对比 null 和 undefined,是的话就会返回 true。

4.判断两者类型是否为 string 和 number,是的话就会将字符串转换为 number。

5.判断其中一方是否为 boolean,是的话就会把 boolean 转为 number 再进行判断。

6.判断其中一方是否为 object 且另一方为 string、number 或者 symbol,是的话就会把 object 转为原始类型再进行判断。

每日英语
Happiness is time precipitation, smile is the lonely sad.
幸福是年华的沉淀,微笑是寂寞的悲伤。