美文网首页
移动端网页开发填坑

移动端网页开发填坑

作者: 任无名F | 来源:发表于2017-07-05 18:17 被阅读0次

Android

  1. Android的物理返回键如果不做处理,会导致web页面上下级页面之间跳转混乱。
    解决方案:当下级页面跳转到上级页面时,使用location.replace(url),这样不会保留下级页面的历史记录,物理返回键也就不会回退回来。

  2. 如果页面包含position:absolue或fixed的元素,当虚拟键盘唤起时,整个页面UI会出现混乱,其中absolue比fixed产生的混乱还要诡异。这是因为Android虚拟键盘唤起时,页面的高度会重新计算而变小。
    解决方案:有虚拟键盘唤起的页面,不要使用absolute定位,使用fixed定位的元素的情况,可以监听window.onresize事件,当document.body.clientHeight变小时,把fixed定位的元素临时修改为static定位;document.body.clientHeight恢复时,再修改回来。


以上解决方案会有些问题,因为当手机横屏的时候也会触发window.onresize并且clientHeight也变小了,所以应该添加一个条件,即同时要判断clientWidth的值,如果clientWidth值变大了那就是手机横屏了,此时不需要做处理,但如果clientWidth没有变化,则按之前的方案修改fixed定位元素为static~
还有另外的几个解决方案,比如禁用手机横屏:

// 注意,这种方案的缺点是兼容性感人
<metaname="screen-orientation" content="portrait">
<metaname="x5-orientation" content="portrait">

或者用js监听手机横屏事件:

// 注意,这种方案仍然有兼容性问题
window.addEventListener("orientationchange", function() {
  switch(window.orientation) {
    case 90:
    case -90:
      // 此时为横屏
      break;
    default:
      // 否则为竖屏
      break;
  }
}, false);
  1. 使用rem单位时,有些Android设备解析出的尺寸会变大,比如华为某款手机,html的font-size明明为36px,但是width为10rem的元素宽度竟然为414px。
    解决方案:在flexible.js之后,还要手写js获取body元素的offsetWidth,判断是否和预期一致,若不一致,则手动设置style.width使之达到预期效果。

iOS

  1. input、select元素自带无法覆盖的样式。
    解决方案:-webkit-appearance:none;

  2. new Date(string)有问题,不支持"2017-7-12",支持"2017/7/12",或者 new Date(2017,7,12,12,12,12) 这种格式。
    以下是我手写的一个转化函数

function createIOSDate(string) {
  let date = new Date(0);
  value = string.replace(/-|:|./g, " ").split(" ");
  date.setFullYear(value[0]);
  date.setMonth(value[1]-1);
  date.setDate(value[2]);
  date.setHours(value[3]);
  date.setMinutes(value[4]);
  date.setSeconds(value[5]);
  return date;
}

综合

  1. 在zepto.js的某些版本,tap事件有bug,点击会触发两次回调函数。
    解决方案:将源码中的 touchend 修改为 touchEnd。

  2. 网页常用meta标签

<!-- viewport 禁止用户缩放,若使用flexible.js则会自动设置 -->
<meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no">

<!-- 优先使用 IE 最新版本和 Chrome -->
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />

<!-- 是否启用 WebApp 全屏模式,删除苹果默认的工具栏和菜单栏 -->
<meta name="apple-mobile-app-capable" content="yes">

<!-- 改变顶部状态条的颜色 -->
<meta name="apple-mobile-app-status-bar-style" content="black">

<!-- 页面描述 -->
<meta name="description" content="">

<!-- 页面关键词 -->
<meta name="keywords" content="html, css, js">

<!-- 忽略页面中的数字识别为电话,忽略email识别 -->
<meta name="format-detection" content="telphone=no, email=no"/>

<!-- DNS预解析 -->
<meta http-equiv="x-dns-prefetch-control" content="on" />
<link rel="dns-prefetch" href="http://a.b.c.com" />
  1. 手机端的chrome浏览器以及facebook app中的浏览器,都会有一个效果,当网页内容超过一屏时,会改变顶部地址栏的高度,时大时小或隐或现。这导致浏览器可视高度发生变化,在实现动态吸顶效果时候会被坑。
    解决方案:监听window的resize事件,根据window.innerHeight调整元素位置。

  2. 在最新的 DOM 规范中,事件绑定函数的第三个参数变成了对象:

target.addEventListener(type, listener[, options]);

我们可以通过传递 {passive: true} 来明确告诉浏览器,事件处理程序不会调用 preventDefault 来阻止默认滑动行为,从而提高事件监听的性能。

  1. 移动端canvas的width、height不支持rem单位。
    解决方案:使用js计算百分比尺寸,再为canvas赋值。

相关文章

  • 移动端网页开发填坑

    Android Android的物理返回键如果不做处理,会导致web页面上下级页面之间跳转混乱。解决方案:当下级页...

  • iOS端IM开发从入门到填坑

    iOS端IM开发从入门到填坑 iOS端IM开发从入门到填坑

  • 中高级前端必须注意的40条移动端H5坑位指南(转载)

    前言 不知不觉在网易已有三年半,占了一半时间都在与移动端打交道,整个阶段都是遇坑填坑的学习过程。移动端开发在前端里...

  • 【建议收藏】2021字节跳动、腾讯、阿里巴巴等一线互联网校招面试

    前言 不知不觉在网易已有三年半,占了一半时间都在与移动端打交道,整个阶段都是遇坑填坑的学习过程。移动端开发在前端里...

  • HTML基础

    新的征程 web前端介绍 web前端开发做什么 pc端web开发;移动端web开发;混合app开发;网页游戏/移动...

  • 移动端开发相关

    超齐全的移动端开发的坑 参考 进行开发调试的时候可以安装browser-sync 移动端分类 Native 原...

  • Open GL工程的搭建

    引子:移动端开发经过这么多年的开发,已经越来越成熟了,而且由于网页端技术的野蛮发展,移动端开发已经越来越式微啦。在...

  • 动态rem

    layout 和 screen的宽度 在比较遥远的时候,网页还是在pc端流行,很少有人开发移动端网页,所有网页的宽...

  • Objective-C和JavaScript交互

    现在的移动端开发,为了提高开发效率,或者为了推广多变的活动,更多的是采用网页和原生交叉的开发方式。所以原生和网页端...

  • Vue 移动端webApp填坑

    1.IOS滚动不平滑的问题 在移动端特别是iOS中,当滚动屏幕时会发现手指一拿开滚动就停止,这种用户体验效果很不好...

网友评论

      本文标题:移动端网页开发填坑

      本文链接:https://www.haomeiwen.com/subject/dxgqhxtx.html