思路:首先获取到两个事件源,使用keyup事件,如果快递单号里面的值value为空时,就隐藏上面的大盒子,否则就将盒子出现并且将快递单号的获取来的值赋值给大盒子作为内容。当鼠标失去焦点(blur)的时候,就隐藏大盒子。当获得焦点(focus)并且快递单号的值不为空时,就显示这个大盒子。
注:keydown和keypress在文本框里面的特点:他们两个事件触发的时候,文字还没有落入到文本框中。keyup事件触发的时候,文字就已经落入到了文本框里面了。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
<style>
* {
margin: 0;
padding: 0;
}
.search {
position: relative;
width: 178px;
height: 100px;
margin: 100px auto;
}
.con {
display: none;
position: absolute;
top: -40px;
width: 171px;
border: 1px solid rgba(0, 0, 0, 0.2);
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
padding: 5px 0;
font-size: 18px;
line-height: 20px;
color: #333;
}
.con::before {
/* 小三角之美 */
content: "";
width: 0;
height: 0;
position: absolute;
top: 28px;
left: 18px;
border: 8px solid #000;
border-style: solid dashed dashed;
border-color: #fff transparent transparent;
}
</style>
</head>
<body>
<div class="search">
<div class="con">123</div>
<input type="text" placeholder="请输入您的快递单号" class="jd" />
<script>
var con = document.querySelector(".con");
var jd_input = document.querySelector(".jd");
jd_input.addEventListener("keyup", function() {
// console.log("输入内容啦");
if (jd_input.value == "") {
con.style.display = "none";
} else {
con.style.display = "block";
con.innerText = this.value;
}
});
//当我们失去焦点的时候,就隐藏这个con盒子
jd_input.addEventListener("blur", function() {
con.style.display = "none";
});
//当我们获得焦点,就显示这个con盒子
jd_input.addEventListener("focus", function() {
if (this.value != "") {
con.style.display = "block";
}
});
</script>
</div>
</body>
</html>