Malunan个人博客|IT技术博客 Malunan个人博客|IT技术博客
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
    • HTML
    • CSS
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • 脚本
  • 剪辑
关于
  • 网站
  • 常用的前端轮子
  • 工具网站
  • 软件工具
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

Lunan Ma

升职加薪搞钱~
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
    • HTML
    • CSS
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • 脚本
  • 剪辑
关于
  • 网站
  • 常用的前端轮子
  • 工具网站
  • 软件工具
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 技术文档

    • Git使用手册
    • Markdown使用教程
    • npm常用命令
    • 移动端兼容问题
      • 1.flex 布局 justify-content: end;不生效问题
        • 原因
        • 解决
      • 2.ios右滑返回,页面卡顿、反应慢
      • 原因
      • 解决
      • 3.移动端ios 单选框radio点击圆点不触发事件问题解决
      • 原因
      • 解决思路:
      • 4.fastclick 解决移动端点击2次不成功
        • fastclick
        • 点击穿透问题
    • 常用cmd命令
    • npm packageJson属性详解
    • yaml语言教程
    • Git修改分支名
    • javaScript-时间相加,超过24小时继续累加
    • 获取视频文件第一帧
    • 前端获取文件下载进度
    • 前端获取上传的视频图片详细信息
    • 解决拖拽时,如果元素内有input,无法选中文本的问题
    • css点击穿透
    • vue插槽传参
    • 谷歌浏览器的kiosk模式
    • 前台下载后台返的二进制文件流
    • css实现无缝切换跑马灯样式
    • 前端优化规范
    • 懒加载+无感删除list思路
  • GitHub技巧

  • Nodejs

  • 博客搭建

  • 脚本

  • 技术
  • 技术文档
MaLunan
2024-11-12
目录

移动端兼容问题

# 1.flex 布局 justify-content: end;不生效问题

# 原因

flex-end和end效果一样,但是兼容性flex-end更好 end ios部分版本不兼容,部分老浏览器不兼容

# 解决

flex 布局 justify-content: flex-end;

# 2.ios右滑返回,页面卡顿、反应慢

# 原因

返回页面中,如果返回页面时有复杂逻辑,或者dom重绘多次,会导致卡顿

# 解决

给指定元素(dom重绘频繁)设置css

 transform: translate3d(0, 0, 0);
1

利用 GPU 加速渲染,速度就快了

# 3.移动端ios 单选框radio点击圆点不触发事件问题解决

# 原因

ios移动端radio 点击背景可以触发事件,点击圆点或者文字不触发事件,点不动 可能是ios不兼容问题

# 解决思路:

让圆点和文字点击事件不生效,点击时,直接点击下方的元素就好了 给圆点元素添加点击穿透属性:pointer-events: none 就好了

/deep/ .el-radio__input {
    pointer-events: none;
  }
  /deep/ .el-radio__label {
    pointer-events: none;
  }
  /deep/ .el-radio__inner {
    pointer-events: none;
  }
  /deep/ .el-radio__original {
    pointer-events: none;
  }
1
2
3
4
5
6
7
8
9
10
11
12

# 4.fastclick 解决移动端点击2次不成功

# fastclick

FastClick是专门未解决移动端浏览器300ms点击延迟和点击穿透问题所开发的一个轻量级的库。FastClick实现原理是在检测到touchend事件的时候,会通过DOM自定义事件立即发出模拟一个click事件,并把浏览器在300ms之后的click事件阻止掉。

# 点击穿透问题

说完移动端点击300ms延迟的问题,还不得不提一下移动端点击穿透的问题。可能有人会想,既然click点击有300ms的延迟,那对于触摸屏,我们直接监听touchstart事件不就好了吗? 使用touchstart去代替click事件有两个不好的地方。 第一:touchstart是手指触摸屏幕就触发,有时候用户只是想滑动屏幕,却触发了touchstart事件,这不是我们想要的结果; 第二:使用touchstart事件在某些场景下可能会出现点击穿透的现象。

什么是点击穿透? 假如页面上有两个元素A和B。B元素在A元素之上。我们在B元素的touchstart事件上注册了一个回调函数,该回调函数的作用是隐藏B元素。我们发现,当我们点击B元素,B元素被隐藏了,随后,A元素触发了click事件。

这是因为在移动端浏览器,事件执行的顺序是touchstart > touchend > click。而click事件有300ms的延迟,当touchstart事件把B元素隐藏之后,隔了300ms,浏览器触发了click事件,但是此时B元素不见了,所以该事件被派发到了A元素身上。如果A元素是一个链接,那此时页面就会意外地跳转。

编辑 (opens new window)
上次更新: 2024/11/12, 10:05:25
npm常用命令
常用cmd命令

← npm常用命令 常用cmd命令→

最近更新
01
懒加载+无感删除list思路
11-12
02
前端优化规范
03-25
03
css实现无缝切换跑马灯样式
03-05
更多文章>
Theme by Vdoing | Copyright © 2019-2024 LuNan Ma | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式