首頁 > web前端 > js教程 > 主體

Javascript小案例:仿淘寶搜尋框使用者輸入

一个新手
發布: 2017-09-06 10:01:38
原創
1495 人瀏覽過


淘寶是我們常用的一個線上購物平台,打開淘寶網首頁,找到淘寶首頁的搜尋框,如下如所示:

Javascript小案例:仿淘寶搜尋框使用者輸入

大家可以看到,當頁面一打開,搜尋框中就可以看到灰色字體“少女高跟鞋”,還有閃爍的遊標。當使用者點擊輸入的時候,灰色字消失。當使用者清空文字方塊的所有內容的時候,灰色字會自動恢復。

接下來,這個小案例就是要介紹如何實現這種效果,也就是使用者輸入事件。

判斷使用者輸入的事件有 oninputonpropertychange 。當然,想必你能想到,由於瀏覽器相容的問題,他們出現的場合有所不同。 正常瀏覽器支援oninput ,而 IE6、IE7、IE8  支援的  onpropertychange 。

為了節省時間,不再模仿淘寶CSS樣式。

程式碼及解析:

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <title>判断用户输入事件第2遍oninput 和onpropertychange 的用法</title></head>
 <style>
        .search {            
        width:300px;            
        height: 30px;            
        margin: 100px auto;            
        position: relative;        
        }
        .search input {            
        width:200px;            
        height:25px;        
        }
        .search label {            
        font-size: 12px;            
        color:#ccc;            
        position: absolute;            
        top:8px;            
        left:10px;            
        cursor: text;        
        }
    </style>
    <script type="text/javascript">
    业务逻辑分析://           
    1.内容为空时,光标和默认字显示在搜索框。自动获取焦点//           
    2.当输入内容时,默认字消失。用oninput事件

        window.onload = function () {
            function $(id){ return document.getElementById(id);}
            $("txt").focus();//自动获取光标方法
            $("txt").oninput = $("txt").onpropertychange = function () {
            //oninput 大部分浏览器支持  检测用户表单输入内容
            //onpropertychange  ie678  检测用户表单输入内容
                if ( this.value == ""){                    
                // 首先判断文本框里的值是否为空。注意用双等号!
                    $("message").style.display = "block";
                } else {
                    $("message").style.display = "none";
                }
            }
        }    </script>  <body><p class="search">
    <input type="text" id="txt">
    <label for="txt" id="message">仿淘宝搜索框</label>
    <!-- 注意label 中for属性 值指向 input 的id值 ,意思是把label标签和input表单相关联。
    label 元素不会向用户呈现任何特殊效果。当用户在label元素内点击文本, 浏览器就会自动将焦点转到和标签相关联的表单控件上。 --></p></body></html>
登入後複製

效果:

Javascript小案例:仿淘寶搜尋框使用者輸入

#不積蹺步無以至千里,一個大的網站就是由一個一個小的功能做起來的,重在實戰,重在敲程式碼,一個案例敲三遍,直到爛熟於心,相信日積月累,一定可以成為大牛。自勉,共勉。謝謝!

以上是Javascript小案例:仿淘寶搜尋框使用者輸入的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板