当前位置:

el-input 密码输入框 显示隐藏优化

访客 2024-04-24 714 0

由于网站整体用的是elementui样式,但是在使用过程发现,type为password类型的输入框,若使用show-password参数虽然可以做到点击一下隐藏再点击一下显示的效果,但是页面的交互显示的一直都是这个样子的:小图标,显然我们想要的是可以“睁眼”和“闭眼”的小图标,SO就需要我们DIY一下子(指时间短暂或动作迅速)(指时间短暂或动作迅速)了。

准备图标

首先我们需要找到两个心仪的小图标:
``

创建div

<el-inputid="passwordinput":type="pwdType"autocomplete="off"v-model="password"placeholder="请输入密码"></el-input><img:src="seen?openeye:offeye"@click="changeye()"class="eye">

设置样式

.eye{width:18px;height:20px;position:absolute;left:93%;top:42%;}

定义数据

data(){return{`seen:'',pwdType:'password',openeye:require('../../static/assets/images/icons/openeye.jpg'),offeye:require('../../static/assets/images/icons/offeye.jpg'),password:null}}``

定义函数

changeye(){this.pwdType=this.pwdType==='password'?'text':'password'this.seen=!this.seen}

兼容问题

你以为到这里就到这里就大功告成了嘛,nonono当你使用MicrosoftEdge查看的时候会发现,这个浏览器竟然自己带隐藏和显示的小图标,我们需要把自带的图标隐藏掉以解决兼容性的问题

//注:要放到<style>中,而不是<stylescoped>中!#passwordinput::-ms-reveal{display:none;}#passwordinput::-ms-clear{display:none;}#passwordinput::-o-clear{display:none;}

以上大功告成!

发表评论

  • 评论列表
还没有人评论,快来抢沙发吧~