大家好,我是刘布斯。
经常开发 H5 的小伙伴,肯定会经常遇到一些奇奇怪怪的兼容性问题,比如 iOS 上的弹窗,低版本 Android 的白屏现象等等。
今天给大家分享一位滴滴的前端同学,在工作中总结的一些 H5 开发经验。
ios中使用border-radius配合overflow:hidden出现了失效的情况:
出现此问题的原因是因为ios手机会在transform的时候导致border-radius失效
解决方法:在使用动画效果带transform的元素的上一级div元素的css加上下面语句:
-webkit-transform:rotate(0deg);
在部分ios手机上会出现以下情况:
在目标元素上设置font-size = line-height
,并加上以下单行省略代码:
.text-overflow {
display: -webkit-box;
overflow : hidden;
text-overflow: ellipsis;
word-break: break-all;
-webkit-line-clamp: 1;
-webkit-box-orient: vertical;
}
或者:
.text-overflow {
overflow : hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
由于不同系统包含的字体的行高不一致,即使设置了height = line-height
一样会有以上问题
经过测试,在height = line-height = font-szie
的情况下,加上padding-top: 1px
可以解决这个问题,即在需要使用单行省略的地方加上:
.demo {
height: 28px;
line-height: 28px;
font-size: 28px;
padding-top: 1px;
}
如:<div class="text-overflow demo">我是需要进行单行省略的文案</div>
解决方案:
button:focus {
outline: none;
}
需求中经常需要实现一类效果:优惠券打孔,如下图所示:
通常情况下会找设计采用图片的的形式,但这个方案最大的缺陷是无法适配背景的变化。因此,我们可以采用如下方案,左右两侧各打一个孔,且穿透背景:
具体细节可以参考这篇文章:纯 CSS 实现优惠券透明圆形镂空打孔效果
navigator.clipboard兼容性不是很好,低版本浏览器不支持
解决方案:
const copyText = (text: string) => {
return new Promise(resolve => {
if (navigator.clipboard?.writeText) {
return resolve(navigator.clipboard.writeText(text))
}
// 创建输入框
const textarea = document.createElement('textarea')
document.body.appendChild(textarea)
// 隐藏此输入框
textarea.style.position = 'absolute'
textarea.style.clip = 'rect(0 0 0 0)'
// 赋值
textarea.value = text
// 选中
textarea.select()
// 复制
document.execCommand('copy', true)
textarea.remove()
return resolve(true)
})
}
这个问题是由webpack缓存导致的,在vue.config.js中添加以下代码:
config.module.rule('vue').uses.delete('cache-loader')
具体原因见:UnoCSS webpack插件原理
在我们的业务需求中,覆盖的人群很广,涉及到的机型也很多。于是我们发现在部分低端机型下(oppo R11、R9等),有很多请求只有options请求,没有真正的业务请求。导致用户拿不到数据,报network error
错误,我们的埋点数据也记录到了这一异常。
在我们的这个项目中,我们的后台有两个,一个提供物料,一个提供别的数据。但是奇怪的是,物料后台是可以正常获取数据,但业务后台就不行!
经过仔细对比二者发送的options请求,发现了问题所在:
发现二者主要存在以下差异:
于是我便开始排查两个响应头的兼容性,发现在这些低端机型上,Access-Control-Allow-Headers: *
确实会有问题,这些旧手机无法识别这个通配符,或者直接进行了忽略,导致options请求没过,自然就没有后续真正的请求了。
解决方案:由后台枚举前端需要的headers,在Access-Control-Allow-Headers
中返回。
还没有使用过我们刷题网站(https://fe.ecool.fun/)或者刷题小程序的同学,如果近期准备或者正在找工作,千万不要错过,题库主打无广告和更新快哦~。
老规矩,也给我们团队的辅导服务打个广告。
原文链接:https://juejin.cn/post/7372396174249459750