最近我注意到谷歌浏览器开始自动完成我们构建jquery表时动态生成的所有搜索栏。所有这些字段都不是表单的一部分,但谷歌决定在其中建议登录值。我试图解决初始化回调并使用autocomplete
属性,但以下解决方案都不起作用。我在 Firefox/Safari 中没有遇到过同样的问题。任何有助于理解问题的帮助将不胜感激。
autocomplete="off"
autocomplete="false"
autocomplete="autocompleterandom"
这是我们如何初始化表
newTable$.DataTable({
paging: true,
pageLength: 20,
lengthMenu: [15, 30, 60, 80],
search: {
search: _this.searchValues[newTable$.data('type')]
},
initComplete: function() {
$('.section input[type="search"]').prop('name', 'autocompleterandom');
$('.section input[type="search"]').prop('autocomplete', 'autocompleterandom');
}
});
这是生成的搜索栏的样子
<div id="DataTables_Table_1_filter" class="dataTables_filter"> .
<label>Search:
<input type="search" class="" placeholder="" aria-controls="DataTables_Table_1"
name="autocompleterandom" autocomplete="autocompleterandom">
</label>
</div>
经过几个小时的研究,这似乎是一个 chrome 的“功能”,现在 chrome 建议在整个应用程序中保存密码:(
https://bugs.chromium.org/p/chromium/issues/detail?id=587466
我有同样的问题,解决方案是把这两行:
$(document).ready(function(){
$("input[type='search']").wrap("<form>");
$("input[type='search']").closest("form").attr("autocomplete","off");
});
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句