解决浏览器自动填充账号密码问题

一、背景介绍

        今天遇到了页面修改密码时首次进入页面会被浏览器填充上已经保存的该网址的账号密码的bug。经过问题排查:浏览器会识别type="password"的输入框,将密码就行填充,所以出现了该bug。

二、解决思路

        经过百度后大概找到了以下几个方案

  • 设置autocomplete="off"
  • 设置autocomplete="new-password",
  • 在用户名密码输入框之前, 再写假的密码框让他填充
  • 将两个input框分开,在中间加其他的输入框,设置定位或透明度将他隐藏
  • 将type="password"改为type="text"

三、具体实现

        我下面介绍设置autocomplete和将type="password"改为type="text"的实现方式。

        (1)设置autocomplete

                autocomplete 属性规定输入字段是否应该启用自动完成功能。自动完成允许浏览器预测对字段的输入。当用户在字段开始键入时,浏览器基于之前键入过的值,应该显示出在字段中填写的选项。

                禁止浏览器表单自动填充

                普通文本框添加 autocomplete="off",密码输入框添加 autocomplete="new-password"。

<input type="text" autocomplete="off" name="userName"/>

<input type="password" autocomplete="new-password" name="password"/>

        (2)将type="password"改为type="text"

                既然问题出现在type="password"上,手用type="text"的输入框,这样就不会被检测为password,也就不可能有填充。但是该方法存会没有密码输入框密文及小眼睛密文切换效果。下面CSS只实现了文字变成密文,没有实现小眼睛效果。

<input type='text' style={{ letterSpacing: '0.3em', WebkitTextSecurity: 'disc', MozTextSecurity: 'disc', textSecurity: 'disc' }} />

四、总结

        上面讲到的两种方法,(1)虽然解决了默认填充问题,但是会存在点击输入框浏览器提示已经保存的密码列表问题,优点是保留了type='password'相关样式。(2)对该问题解决效果更好,但是失去了原本type='password'小眼睛及密文样式,需要自己再写CSS实现。

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值