TAT.tennylv 移动 web 问题小结
In CSS3,HTML5,Web开发,经验心得 on 2015年06月14日 by view: 26,428
29

Meta 标签:

这个想必大家都知道,当页面在手机上显示时,增加这个 meta 可以让页面强制让文档的宽度与设备的宽度保持 1:1,并且文档最大的宽度比例是 1.0,且不允许用户点击屏幕放大浏览。

这两个属性分别对 ios 上自动识别电话和 android 上自动识别邮箱做了限制。

 

  获取滚动条的值:

桌面浏览器中想要获取滚动条的值是通过 document.scrollTop 和 document.scrollLeft 得到的,但在 iOS 中你会发现这两个属性是未定义的,为什么呢?因为在 iOS 中没有滚动条的概念,在 Android 中通过这两个属性可以正常获取到滚动条的值,那么在 iOS 中我们该如何获取滚动条的值呢?就是上面两个属性,但是事实证明 android 也支持这属性,所以索性都用 woindow.scroll.

 

禁止选择文本:

禁止用户选择文本,ios 和 android 都支持

 

屏蔽阴影:

亲测,可以同时屏蔽输入框怪异的内阴影,解决 iOS 下无法修改按钮样式,测试还发现一个小问题就是,加了上面的属性后,iOS 下默认还是带有圆角的,不过可以使用 border-radius 属性修改。

 

 css 之 border-box:

那我想要一个元素 100% 显示,又必须有一个固定的 padding-left/padding-right,还有 1px 的边框,怎么办?这样编写代码必然导致出现横向滚动条,肿么办?要相信问题就是用来解决的。这时候伟大的 css3 为我们提供了 box-sizing 属性,对于这个属性的具体解释不做赘述(想深入了解的同学可以到 w3school 查看,要知道自己动手会更容易记忆)。让我们看看如何解决上面的问题:

 

 css3 多文本换行:

Webkit 支持一个名为-webkit-line-clamp 的属性,参见链接,也就是说这个属性并不是标准的一部分,可能是 Webkit 内部使用的,或者被弃用的属性。需要注意的是 display 需要设置成 box,-webkit-line-clamp 表示需要显示几行。

 

 Retina 屏幕高清图片:

image-set 的语法,类似于不同的文本,图像也会显示成不同的:

  1.   不支持 image-set:在不支持 image-set 的浏览器下,他会支持 background-image 图像,也就是说不支持 image-set 的浏览器下,他们解析 background-image 中的背景图像;
  2.   支持 image-set:如果你的浏览器支持 image-sete,而且是普通显屏下,此时浏览器会选择 image-set 中的 @1x 背景图像;
  3.  Retina 屏幕下的 image-set:如果你的浏览器支持 image-set,而且是在 Retina 屏幕下,此时浏览器会选择 image-set 中的 @2x 背景图像。

 

 

 html5 重力感应事件:

关于 deviceMotionEvent 是 HTML5 新增的事件,用来检测手机重力感应效果具体可参考 http://w3c.github.io/deviceorientation/spec-source-orientation.html

 

移动端 touch 事件:

  • touchstart //当手指接触屏幕时触发
  • touchmove //当已经接触屏幕的手指开始移动后触发
  • touchend //当手指离开屏幕时触发
  • touchcancel//当某种 touch 事件非正常结束时触发

这 4 个事件的触发顺序为:

touchstart -> touchmove ->  touchend ->touchcancel

对于某些 android 系统 touch 的 bug:

比如手指在屏幕由上向下拖动页面时,理论上是会触发 一个 touchstart ,很多次 touchmove ,和最终的 touchend ,可是在 android 4.0 上,touchmove 只被触发一次,触发时间和 touchstart 差不多,而 touchend 直接没有被触发。这是一个非常严重的 bug,在 google Issue 已有不少人提出 , 这个很蛋疼的 bug 是在模拟下拉刷新是遇到的尤其当 touchmove 的 dom 节点数量变多时比出现,当时解决办法就是用 settimeout 来稀释 touchmove。

 

单击延迟:

click 事件因为要等待双击确认,会有 300ms 的延迟,体验并不是很好。

开发者大多数会使用封装的 tap 事件来代替 click 事件,所谓的 tap 事件由 touchstart 事件 + touchmove 判断 + touchend 事件封装组成。

Creating Fast Buttons for Mobile Web Applications

Eliminate 300ms delay on click events in mobile Safari

 

IOS 里面 fixed 的文本框焦点居中

在 ios 里面,当一个文本框的样式为 fixed 时候,如果这个文本框获得焦点,它的位置就会乱掉,由于 ios 里面做了自适应居中,这个 fixed 的文本框会跑到页面中间。类似:

 

解决办法有两个:

可以在文本框获得焦点的时候将 fixed 改为 absolute,失去焦点时在改回 fixed,但是这样会让屏幕有上下滑动的体验不太好。

 

还有一种就是用一个假的 fixed 的文本框放在页面顶部,一个 absolute 的文本框隐藏在页面顶部,当 fixed 的文本框获得焦点时候将其隐藏,然后显示 absolute 的文本框,当失去焦点时,在把 absolute 的文本框隐藏,fixed 的文本框显示。

 

最后一种就是顶部的 input 不参与滚动,只让其下面滚动。

 

position:sticky

position:sticky 是一个新的 css3 属性,它的表现类似 position:relative 和 position:fixed 的合体,在目标区域在屏幕中可见时,它的行为就像 position:relative; 而当页面滚动超出目标区域时,它的表现就像 position:fixed,它会固定在目标位置。

浏览器兼容性

由于这是一个全新的属性,以至于到现在都没有一个规范,W3C 也刚刚开始讨论它,而现在只有 webkit nightly 版本和 chrome 开发版 (Chrome 23.0.1247.0+ Canary) 才开始支持它。

另外需要注意的是,如果同时定义了 left 和 right 值,那么 left 生效,right 会无效,同样,同时定义了 top 和 bottom,top 赢~~

移动端点透事件

简单的说,由于在移动端我们经常会使用 tap(touchstart) 事件来替换掉 click 事件,那么就会有一种场景是:

div 是绝对定位的蒙层 z-index 高于 a,而 a 标签是页面中的一个链接,我们给 div 绑定 tap 事件:

我们点击蒙层时 div 正常消失,但是当我们在 a 标签上点击蒙层时,发现 a 链接被触发,这就是所谓的点透事件。

原因:

touchstart 早于 touchend 早于 click。亦即 click 的触发是有延迟的,这个时间大概在 300ms 左右,也就是说我们 tap 触发之后蒙层隐藏,此时 click 还没有触发,300ms 之后由于蒙层隐藏,我们的 click 触发到了下面的 a 链接上。

解决办法:

1 尽量都使用 touch 事件来替换 click 事件。

2 阻止 a 链接的 click 的 preventDefault

 

base64 编码图片替换 url 图片

u 在移动端,网络请求是很珍贵的资源,尤其在 2g 或者 3g 网络下,所以能不发请求的资源都尽量不要发,对于一些小图片 icon 之类的,可以将图片用 base64 编码,来减少网络请求。

 

手机拍照和上传图片

<input type="file"> 的 accept 属性

 

动画效果时开启硬件加速

我们在制作动画效果时经常会想要改版元素的 top 或者 left 来让元素动起来,在 pc 端还好但是移动端就会有较大的卡顿感,这么我们需要使用 css3 的  transform: translate3d; 来替换,

此效果可以让浏览器开启 gpu 加速,渲染更流畅,但是笔着实验时在 ios 上体验良好,但在一些低端 android 机型可能会出现意想不到的效果。

 

快速回弹滚动

在 iOS 上如果你想让一个元素拥有像 Native 的滚动效果,你可以这样做:

经笔着测试,此效果在不同的 ios 系统表现不一致,

对于局部滚动,ios8 以上,不加此效果,滚动的超级慢,ios8 一下,不加此效果,滚动还算比较流畅

对于 body 滚动,ios8 以上,不加此效果同样拥有弹性滚动效果。

 

持续更新中。。

ios 和 android 局部滚动时隐藏原生滚动条

android

ios

使用一个稍微高一些 div 包裹住这个有滚动条的 div 然后设置 overflow:hidden 挡住之

设置 placeholder 时候 focus 时候文字没有隐藏

移动端不同的 input 对应不同的键盘展示样式

ios ---- android

type email

type url

type tel

type search

 

background-image 和 image 的加载区别

在网页加载的过程中,以 css 背景图存在的图片 background-image 会等到结构加载完成(网页的内容全部显示以后)才开始加载,而 html 中的标签 img 是网页结构(内容)的一部分会在加载结构的过程中加载,换句话讲,网页会先加载标签 img 的内容,再加载背景图片 background-image,如果你用引入了一个很大的图片,那么在这个图片下载完成之前,img 后的内容都不会显示。而如果用 css 来引入同样的图片,网页结构和内容加载完成之后,才开始加载背景图片,不会影响你浏览网页内容。

未完待续

参考资料:http://www.nihaoshijie.com.cn/index.php/archives/455

原创文章转载请注明:

转载自AlloyTeam:http://www.alloyteam.com/2015/06/yi-dong-web-wen-ti-xiao-jie/

  1. wubai 2017 年 7 月 8 日

    加*号 会反应迟钝

  2. 李白 2017 年 3 月 29 日

    有多少是空心 www.kxhtml.com 这样的众包网站:价格标准 100 元/页面,专属项目经理管这管那质量,不小心点了退款钱到了,靠谱技工为个好评就差做牛做马了,要不去看看?www.kxhtml.com

  3. mylg 2017 年 3 月 17 日

    mozilla/5.0 (linux; android 6.0; dig-al00 build/huaweidig-al00; wv) applewebkit/537.36 (khtml, like gecko) version/4.0 chrome/55.0.2883.91 mobile safari/537.36 有没有遇到过在这个 webview 下面,rem 解析不正常的情况吗

  4. 手机端Web开发中遇到的那些问题 - 李刚博客 2016 年 9 月 24 日

    […] 移动 web 问题小结 无线 Web 开发经验谈 […]

  5. 手机端Web开发中遇到的那些问题 – IT知库 2016 年 9 月 24 日

    […] 移动 web 问题小结 […]

  6. Ryn_xiao 2016 年 3 月 28 日

    谢谢分享,很好很强大,收藏先

  7. 冷柔 2015 年 12 月 15 日

    呵呵,非常感谢,很好很强大

  8. 冷柔 2015 年 12 月 15 日

    [不]

  9. biaotwo 2015 年 12 月 11 日

    好东西,不错加油

  10. 随你走下去 2015 年 10 月 12 日

    挺齐全的

  11. 专注互联网开发 2015 年 9 月 28 日

    收集的蛮全的

  12. LoveSnow 2015 年 7 月 4 日

    监听 form 的提交事件.

  13. Andy 2015 年 6 月 26 日

    支持 image-set:如果你的浏览器支持 image-sete,而且是普通显屏下,此时浏览器会选择 image-set 中的 @1x 背景图像; 这句里有一个小失误,image-set 而不是 image-sete 哦~~

  14. Web前端之家 2015 年 6 月 24 日

    收藏了,不错

  15. 大神 2015 年 6 月 18 日

    但是笔着实验时在 ios 上体验良好

    笔者

    iPhone5s 、ios8+ 偶遇字体大小设置无效

    加上这个就解决了

    -webkit-text-size-adjust:none;

    • TAT.tennylv

      TAT.tennylv 2015 年 6 月 18 日

  16. swing 2015 年 6 月 17 日

    position:sticky
    这个属性现在应该已经不能用了,手机端想实现滚动到指定位置再 fixed,效果应该都不好,都会有迟疑,我们解决了很久没搞定

    • TAT.tennylv

      TAT.tennylv 2015 年 6 月 18 日

      兄弟 这个属性在 ios 上是可以用的 我们现在就在用 在 android 上用不了 我们采用的方式是监听滚动事件来动态设置 postion

  17. Kelvin 2015 年 6 月 15 日

    1. translate3d 对 z-index 会有影响.
    2. 安卓 4.4 以上的 webview , 也就是 App 内置浏览器不支持 input[type=file] 这个 google grounp 里很多 issue.
    3. 内存较低的安卓机 input[type=file] 会闪退.
    4. 上面文章作者笔误
    这 4 个事件的触发顺序为:
    touchstart -> touchmove -> touchmove ->touchend
    貌似没写 touchcancel
    5. -webkit-user-select:none 如果设置给文本框, 会导致 ios 出现键盘, 但是无法输入.
    6. viewport 的 width 可以直接设置宽度是 640, 但是在 ios 的 webview 里, 如果没有 webview 没有设置适配属性, 就会导致页面变宽出现超出的部分.

    都是以前的碰到的一些坑.

    • TAT.tennylv

      TAT.tennylv 2015 年 6 月 15 日

      1 translate3d 对 z-index 会有影响. 这个是在什么情况下有影响?机型?系统?
      2. 安卓 4.4 以上的 webview , 也就是 App 内置浏览器不支持 input[type=file] 这个 google grounp 里很多 issue. 这个我专门找了个手机验证了一下没发现有问题。
      3. 内存较低的安卓机 input[type=file] 会闪退. 这个有待测试
      4. 上面文章作者笔误 已修改

      • 草珊瑚 2015 年 6 月 19 日

        translate3d 对 z-index 会有影响是因为改变了 stack context

  18. yc 2015 年 6 月 15 日

    好多错别字啊

    • TAT.tennylv

      TAT.tennylv 2015 年 6 月 15 日

      不好意思纯手敲的 我再去检查一下啊这些错别字

  19. 光军 2015 年 6 月 15 日

    “IOS 里面 fixed 的文本框焦点居中” 里的 css,position 写错了

    • TAT.tennylv

      TAT.tennylv 2015 年 6 月 15 日

      不好意思纯手敲的 我再去检查一下啊

  20. 梅子 2015 年 6 月 14 日

    你好!我上周也是遇到 “IOS 里面 fixed 的文本框焦点居中” 的问题,当非焦点的状态时,我采用的是 fixed,当焦点的时候会隐藏底部的按钮,这样的切换方法。但是遇到一个问题是点击 ios 的按钮 “完成” 时,可以解除聚焦的状态,能及时改成 fixed, 但是点击 android 的完成按钮时,是不能被识别。请问一下,有什么好方法能识别这个安卓的 “完成按钮” 吗?

    • TAT.tennylv

      TAT.tennylv 2015 年 6 月 15 日

      隐藏底部按钮是什么意思?可以加我 qq 441403517

    • xshort 2015 年 6 月 18 日

      安卓原生可以监听键盘弹出状态,使用 hybrid 方式可以处理

发表评论