https://segmentfault.com/q/1010000000671971
chrome浏览器自动填充表单的黄色背景高亮(#FAFFBD)一直困扰着我,我之前没想着理它,可是最近一个登陆框,需要用到图标,于是我草率的直接设置在input元素里面,结果问题就来了,很难看很难看,因此还是总结一下。
这个问题,在2008年的时候就已经存在了,隔了好几年了,在chromium上面可以找到 Issue 46543,但是官方好像没有理这个问题,英文没怎么看懂,谁理解的,可以给大家分享一下。

思路一: 打补丁

Webkit内核的浏览器有一个-webkit-autofill私有属性,
通过审查元素可以看到这是由于chrome会默认给自动填充的input表单加上input:-webkit-autofill私有属性,然后对其赋予以下样式:

  1. input:-webkit-autofill, textarea:-webkit-autofill, select:-webkit-autofill {
  2. background-color: rgb(250, 255, 189); /* #FAFFBD; */
  3. background-image: none;
  4. color: rgb(0, 0, 0);
  5. }

因此我们就会想到覆盖这个样式,代码如下,但是依然不能覆盖原有的背景、字体颜色。需要注意的是:加 !important 依然不能覆盖原有的背景、字体颜色,除了chrome默认定义的background-colorbackground-imagecolor不能用 !important 提升其优先级以外,其他的属性均可使用!important提升其优先级。

  1. input:-webkit-autofill, textarea:-webkit-autofill, select:-webkit-autofill {
  2. background-color: #FFFFFF;
  3. background-image: none;
  4. color: #333;
  5. /* -webkit-text-fill-color: red; //这个私有属性是有效的 */
  6. }
  7. input:-webkit-autofill:hover {
  8. /* style code */
  9. }
  10. input:-webkit-autofill:focus {
  11. /* style code */
  12. }

情景一:input文本框是纯色背景的

解决办法:

  1. input:-webkit-autofill {
  2. -webkit-box-shadow: 0 0 0px 1000px white inset;
  3. -webkit-text-fill-color: #333;
  4. }

情景二:input文本框是使用图片背景的

解决办法:

  1. if (navigator.userAgent.toLowerCase().indexOf("chrome") >= 0)
  2. {
  3. var _interval = window.setInterval(function () {
  4. var autofills = $('input:-webkit-autofill');
  5. if (autofills.length > 0) {
  6. window.clearInterval(_interval); // 停止轮询
  7. autofills.each(function() {
  8. var clone = $(this).clone(true, true);
  9. $(this).after(clone).remove();
  10. });
  11. }
  12. }, 20);
  13. }

下面的js不是太靠谱

  1. if (navigator.userAgent.toLowerCase().indexOf("chrome") >= 0) {
  2. $(window).load(function(){
  3. $('input:-webkit-autofill').each(function(){
  4. var clone = $(this).clone(true, true);
  5. $(this).after(clone).remove();
  6. });
  7. });
  8. }

思路二: 关闭浏览器自带填充表单功能

设置表单属性 autocomplete="off/on" 关闭自动填充表单,自己实现记住密码

  1. <!-- 对整个表单设置 -->
  2. <form autocomplete="off" method=".." action="..">
  3. <!-- 或对单一元素设置 -->
  4. <input type="text" name="textboxname" autocomplete="off">

网上大部分文章是使用Cookie实现记住用户名、密码。不管是在前端,还是后端都可以实现。本文不对Cookie存储展开讨论。可自行谷歌

其他

stackoverflow.com上面也有类似的回答
Google Chrome form autofill and its yellow background
Override browser form-filling and input highlighting with HTML/CSS