浏览器密码框明文密文兼容edge的问题

在网页中注册会员的时候,经常需要输入用户名(账号)和密码,在输入密码的时候,为了防止用户输错密码,经常会给密码框加一个小功能,就是点击密码框右侧闭着的小眼睛,可以让密文变成明文,同时眼睛是睁开的。用户确认密码无误后,再次点击可变成密文,图片又变成闭着的眼睛,效果 如图所示。

下面是本例中用到的两张眼睛的图片。

这个功能的实现思路是改变密码框的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>
相关推荐
多则惑少则明25 分钟前
Vue开发系列——自定义组件开发
前端·javascript·vue.js
用户2506949216132 分钟前
next框架打包.next文件夹部署
前端
程序猿小蒜35 分钟前
基于springboot的校园社团信息管理系统开发与设计
java·前端·spring boot·后端·spring
一叶难遮天35 分钟前
开启RN之旅——前端基础
前端·javascript·promise·js基础·es6/ts·npm/nrm
申阳36 分钟前
Day 4:02. 基于Nuxt开发博客项目-整合 Inspira UI
前端·后端·程序员
程序猿_极客39 分钟前
【期末网页设计作业】HTML+CSS+JavaScript 猫咪主题网站开发(附源码与效果演示)
前端·css·html·课程设计·网页设计作业
IT古董40 分钟前
【前端】从零开始搭建现代前端框架:React 19、Vite、Tailwind CSS、ShadCN UI 完整实战教程-第1章:项目概述与技术栈介绍
前端·react.js·前端框架
有点笨的蛋42 分钟前
从零搭建小程序首页:新手也能看懂的结构解析与实战指南
前端·微信小程序
爱宇阳42 分钟前
Vue3 前端项目 Docker 容器化部署教程
前端·docker·容器
Irene199143 分钟前
前端缓存技术和使用场景
前端·缓存