您的位置:首页 > 汽车 > 新车 > seo优化软件哪个最好用_南宁定制建站_汽车营销策划方案ppt_成人电脑培训班办公软件

seo优化软件哪个最好用_南宁定制建站_汽车营销策划方案ppt_成人电脑培训班办公软件

2024/11/16 13:20:17 来源:https://blog.csdn.net/u013836242/article/details/142853490  浏览:    关键词:seo优化软件哪个最好用_南宁定制建站_汽车营销策划方案ppt_成人电脑培训班办公软件
seo优化软件哪个最好用_南宁定制建站_汽车营销策划方案ppt_成人电脑培训班办公软件

参考:

完美解决 element-ui input=password 在浏览器会自动填充密码的问题

背景:

领导要求去掉登录页的账号密码表单的自动显示账号密码候选框

定位:

  1. chrome 版本 126.0.6478.127 , 现有表单用的是原生 input 元素, 之前已经加了 autocomplete="off"readonly + onfocus 时去掉 readonly , 看起来之前就尝试去掉候选框了, 但是没啥效果; 账号和密码输入框都会触发, 要不就是一开始不触发, 清空后重新输入 或 多次 tab 切换/点击重新获取焦点后又触发了
  2. 先看 autocomplete 属性, 结果发现 off 和 new-password 都不管用
  3. 之前记得看到过使用额外的隐藏 input 欺骗浏览器的方案, 但是不想改现有表单结构 + 多写代码, 先 pass ;
  4. 再试 readonly , 毕竟之前加的这个, 有时还是生效的, 于是搜到了上面的参考文章, 参考它成功解决问题 — 坑爹的是, 尝试过程中经常是本地 localhost 没问题, 发到测试环境域名后效果不好…

代码:

<!-- vue 写的 --><!-- 原代码 -->
<!-- 遍历配置表单输入框配置对象数组 inputConfig , 显示账号和密码输入框 -->
<input v-model="form[item.attrName]"ref="loginFormInput":type="item.type":name="item.name":id="item.id":placeholder="item.placeholder":autocomplete="item.type === 'password' ? 'on' : 'off'":readonly="item.type !== 'password'"onfocus="this.removeAttribute('readonly');"@blur="blur(item,form[item.val],index)"@focus="focus(index)"@change="change(form[item.val], item.val)"/><!-- 新代码 -->
<input v-model="form[item.val]"ref="loginFormInput":type="item.type":name="item.name":id="item.id":placeholder="item.placeholder"autocomplete="off" // 变动:readonly="true" // 变动// 删除 onfocus@blur="blur(item,form[item.val],index)" // 内部变动@focus="focus(index)" // 内部变动@mousedown="handleMouseDown(index)" // 新增@change="change(form[item.val], item.val)"/><script>export default {methods: {// 动态设置 input 的 readonly , 避免浏览器显示候选框handleMouseDown(index) {const $inputEl = this.$refs.loginFormInput[index];if (this.form[this.inputConfig[index].attrName] === '') {$inputEl.setAttribute('readonly', 'readonly');setTimeout(() => {$inputEl.removeAttribute('readonly');});} else {$inputEl.removeAttribute('readonly');}},focus(index) {// 新增的相关代码// 避免使用 tab 键选中输入框时浏览器显示候选框this.handleMouseDown(index);},blur(item, val, index) {// 新增的相关代码// 失焦时设置 readonly , 不管输入框是否有值, 避免多次 tab 切换输入框后浏览器候选框又显示出来了const $inputEl = this.$refs.loginFormInput[index];$inputEl.setAttribute('readonly', 'readonly');}},watch: {'form.password': {handler: function(val) {// 新增的相关代码// 此处使用 watch 值的变化,因为使用 @input 监听时用拼音输入有问题(可用 compositionstart 解决, 但麻烦)if (!val) {this.handleMouseDown(1);}},deep: true},'form.userName': {handler: function(val) {// 新增的相关代码// 此处使用 watch 值的变化,因为使用 @input 监听时用拼音输入有问题(可用 compositionstart 解决, 但麻烦)if (!val) {this.handleMouseDown(0);}},deep: true}}}
</script>

后记:

额… 领导说不用改了, 我理解错了, 说的不是去掉候选框, 是去掉候选框里某一条记录, 客户自己进密码管理器删了就行…

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com