浏览器自动填充用户名或密码

chrome为了更便捷的用户体验会根据用户保存的用户名或密码进行自动填充,但是有时我们不想使用这功能,想利用autocomplete="off" 关闭此功能,发现关闭不了
例如我需要重新注册一个账号,结果直接将我原先的账号默认填写进表单中了,这样的用户体验很差

image.png

最后发现浏览器自动填充是有规律的,比如 input type="text" 后面如果有 input type="password" 一般就会出现自动填充的问题
网上找了一些方法,有先使用disabled然后再使用定时器移除disabled,发现没什么效果,先将 type 设置成 text 再动态改变成 password 这种方法也是有问题的

我自己使用的方法是将浏览器默认的规则打乱,让其自动填充依旧存在,不过自动填充的input使用绝对定位定到屏幕以外,注意是使用定位的方法,不是使用隐藏的方法,使用 display:none 也是没有效果的

<div class="form-control-row">
  <label><em>用户名</em></label>
  <div class="ui-input width-300">
    <input data-dict="numberLetter" 
      maxlength="14" class="text-hints" id="username"
      name="username" type="text" placeholder="">
    <input type="text" tabindex="-1" class="outside_input"> <!--打乱浏览器默认规则的元素-->
    <input type="password" tabindex="-1" class="outside_input"> <!--打乱浏览器默认规则的元素-->
  </div>
</div>

上面两个input只是起到扰乱作用,添加这两个元素后你会发现浏览器自动填充将内容填充到这里,而这input没有name无法进行正常的表单提交,我们再隐藏这两个元素就好了, 注意使用 tabindex=-1 这样使用tab键就可以不对此获取焦点

<div class="ui-input width-300">
  <input type="text" tabindex="-1" class="outside_input">
  <input autocomplete="off" data-dict="!zh" maxlength="16" 
    class="text-hints" id="password" name="password" type="password" placeholder="">
</div>

类似的填写密码自动填充用户名也可以使用类似的原理

个人感觉这种方法不是最好的方法,如果大家有其他好办法欢迎留言_

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,092评论 19 139
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 28,341评论 1 45
  • Spring Web MVC Spring Web MVC 是包含在 Spring 框架中的 Web 框架,建立于...
    Hsinwong阅读 22,761评论 1 92
  • 我坐在山岗上,看着山坡下面绿油油的庄稼,还是那么高。好几次隐约看见庄稼梢头微动,险情丛生。每一次我都会发出警告大喊...
    古城苍狼阅读 1,877评论 0 1
  • 语文作业: 听写词语“个子,个人,大人,工人,木头,天下”,错的或者不会的在下面写四遍[拳头] 数学作业: 口算题...
    瑞睿家阅读 1,553评论 0 0

友情链接更多精彩内容