网站首页 > 技术文章 正文
前言
虽然最近没怎么开发H5端的应用,但是还是想总结下之前开发移动端遇到的一些问题,顺便加深一下自己的印象。
1.时间戳转换问题
安卓
Date.parse(new Date('xxxx-xx-xx 12:00:00'))
ios
Date.parse(new Date('xxxx/xx/xx 12:00:00'))
兼容写法
Date.parse(newDate('xxxx/xx/xx 12:00:00')) ||Date.parse(newDate('xxxx-xx-xx 12:00:00'))
2.不会弹出键盘 必须满足下面几点
① 文本框获取焦点
② 手指触屏(网页区域,混合开发触屏app头不能让webview弹出键盘)
③ 没有延迟(不会ajax回调,不会延迟)
3.禁止ios弹出各种操作窗口
-webkit-touch-callout:none
4.禁止用户选中文字
-webkit-user-select:none
5.js动态生成的下拉菜单在安卓2.0中不起作用
删除overflow-x:hidden然后在js生成下拉菜单之后聚焦focus
6.ios中文输入法输入英文时会有小空格
用正则
this.value = this.value.replace(/\u2006/g, '');
7.touchmove事件在Android部分机型只触发了一次
在触发函数里面加上e.preventDefault(); 记得将e也传进去。
8.IOS的Safari环境
问题:在做移动端左右滑动的时候,用到了CSS3的Transition属性来进行动画变换,结果每次渲染Transition属性时,出现闪屏现象。
有以下两种解决办法,
方法一:
设置内嵌的元素在 3D 空间如何呈现:保留 3D/
-webkit-transform-style: preserve-3d;
方法二:
设置进行转换的元素的背面在面对用户时是否可见:隐藏)*
webkit-backface-visibility: hidden;
9.input框聚焦,ios出现outline或者阴影,安卓显示正常
input:focus{outline:none}
input:{-webkit-appearance: none;}
10.input 的placeholder属性会使文本位置偏上
line-height: (和input框的高度一样高)---pc端解决方法
line-height:normal ---移动端解决方法
11.input type=number之后,pc端出现上下箭头
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
-webkit-appearance: none !important;
margin: 0;
}
12.ios系统,会将数字当成电话号码,导致变色
<meta name="format-detection" content="telephone=no">
<meta http-equiv="x-rim-auto-match" content="none">
13.禁止安卓识别email
<meta content="email=no" name="format-detection" />
14.ios手机页面里可滚动内容滚动不流畅
-webkit-overflow-scrolling : touch;
总结
如果你有遇到过其他的兼容性问题,并有解决方案,也可以私信投稿噢!
往期精彩文章
深入了解 JavaScript 闭包
如何在不同项目中共用前端资源,从此不加班
一个比较全面的基于axios的封装
查阅更多精彩文章,关注“悲伤日记”
猜你喜欢
- 2024-12-26 现代CSS:纯 CSS 实现路径动画 js路径动画
- 2024-12-26 用几行原生JS就可以实现丝滑的元素过渡效果
- 2024-12-26 HTML5引领网页开发新概念 html5设计网页
- 2024-12-26 一篇文章教会你利用html5和css3实现3D立方体效果图
- 2024-12-26 WEB:讲清楚CSS、Less、Sass、Scss
- 2024-12-26 Slideout.js – 滑出式 Web App 导航菜单
- 2024-12-26 CSS渐变属性的特效 css渐变属性的特效有哪些
- 2024-12-26 改进网站设计的免费jQuery插件Top 7
- 2024-12-26 应用HTML5和CSS3实现举报中心PC端与手机端举报页面的自适应设计
- 2024-12-26 CSS图像 hover 动画效果 css动画from to
- 1509℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 527℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 492℃MySQL service启动脚本浅析(r12笔记第59天)
- 472℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 469℃启用MySQL查询缓存(mysql8.0查询缓存)
- 450℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 429℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 426℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)