在网页中注册会员的时候,经常需要输入用户名(账号)和密码,在输入密码的时候,为了防止用户输错密码,经常会给密码框加一个小功能,就是点击密码框右侧闭着的小眼睛,可以让密文变成明文,同时眼睛是睁开的。用户确认密码无误后,再次点击可变成密文,图片又变成闭着的眼睛,效果 如图所示。
下面是本例中用到的两张眼睛的图片。
这个功能的实现思路是改变密码框的type属性,明文为text,密文为password,最开始是这样实现的:
javascript
<script type="text/javascript">
var eye = document.getElementById('eyes')
var pwd = document.getElementById('pwds')
eye.onclick = function() {
if (pwd.type == "text") {
pwd.type = 'password'
eye.src = './images/close.png'
} else {
pwd.type = 'text'
eye.src = './images/open.png'
}
}
</script>
上面代码在谷歌、safari浏览器上运行没有问题,但是在edge浏览器运行时,edge浏览器自带这个功能,所以会同时出现两张眼睛的图片,如图所示。
所以需要添加是否是edge浏览器的判断代码,使用navigator.userAgent属性进行判断。
javascript
navigator.userAgent.indexOf("Edg") == -1
我们把图片初始状态设置为不可见,如果navigator.userAgent.indexOf("Edg")值为-1,说明不是Edge浏览器,这时我们再让图片显示,执行我们写的script代码。
完整的代码如下:
html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>显示隐藏密码</title>
<style type="text/css">
.box {
position: relative;
width: 400px;
margin: 100px auto;
}
.box input {
width: 330px;
height: 30px;
border: 1px solid #ccc;
outline: none;
}
.box img {
position: absolute;
top: 5px;
right: 30px;
width: 24px;
cursor: pointer;
display: none;
/*初始状态不可见*/
}
</style>
</head>
<body>
<div class="box">
<label for="pwds">密码:</label>
<img src="./images/close.png" id="eyes">
<input type="password" id="pwds" />
</div>
<script>
//判断不是Edge浏览器再执行下面的代码
if (navigator.userAgent.indexOf("Edg") == -1) {
var pwd = document.querySelector("#pwds")
var eye = document.querySelector("#eyes")
eye.style.display = 'block'
eye.onclick = function() {
if (pwd.type == "text") {
pwd.type = 'password'
eye.src = './images/close.png'
} else {
pwd.type = 'text'
eye.src = './images/open.png'
}
}
}
</script>
</body>
</html>