当前位置:编程学习 > JAVA >>

原生javascript学习:百度输入法

今天用 javascript 实现了百度输入法下拉菜单
demo:http://cssplusplus.com/demo/js/2_1_baiduInput0.html
源代码:
01 <!DOCTYPE html>
02 <html>
03 <head>
04 
05 <style>
06 *{margin:0px;padding:0px;}
07 #outer{width:70px;margin:10px auto;font:12px/1.5 Tohoma;}
08 #menu li{list-style-type:none; }
09 li#close{border-top:1px solid #9A99FF;}
10 #menu{margin:6px 0px;border:1px solid #9A99FF;width:68px;display:none;}
11 #menu li a{text-decoration:none;display:block;color: #0000CC;padding:4px 4px;}
12 #menu li a:hover{background:#D9E1F6;;}
13 
14 
15 </style>
16 
17 <script>
18 window.onload = function() {
19     var obtn = document.getElementsByTagName("button")[0];
20     var omenu = document.getElementById("menu");
21     omenu.style.display = "none";
22     obtn.onclick = function() {
23         if (omenu.style.display == "none") {
24             omenu.style.display = "block";
25         } else {
26             omenu.style.display = "none";
27         }
28     }
29 }
30 </script>
31 
32 </head>
33 <body>
34     <div id="outer">
35         <button>输入法</button>
36     <ul id="menu">
37         <li><a href="#">手写</a></li>
38         <li><a href="#">拼音</a></li>
39         <li id="close"><a href="#">关闭</a></li>
40     </ul>
41     </div>
42 </body>
43 </html>
注意如果没有21行的语句:
1 omenu.style.display = "none";
omenu.style.display将会等于空值,这时点击button,第一次if判定将是false,进入else的语句,使omenu.style.display = "none"。换言之,必须在首次点击时,点击两次,才能使menu出现。
其实在 javascript 中,对对象使用style方法,不会修改css里样式,但可以以最高优先级去刷新样式。

 作者:黎宇浩

补充:web前端 , JavaScript ,
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,