为了账号安全,请及时绑定邮箱和手机立即绑定

源生JS 并没封装函数 火狐浏览器 为什么这不行呢?

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>搜索框制作1</title>
    <meta http-equiv='X-UA-Conpatible' content='IE=edge'>
    <style type="text/css">
        *{
            margin: 0;
            padding: 0;
        }
        body{
            background-color: #333;
        }
        .bg-div{
            background-image: url(rem.png);
            widows: 2230px;
            height: 1359px;
            margin:0 auto;
        }
        .logo{
            background-image :url(logo.png);
            width:107px;
            height: 53px;
            float:left;
            margin:-4px 20px 0 0;
        }
        form{
            float:left;
            background-color: #fff;
            padding: 5px;
        }
        .search-one,.search-two{
            border:0;
        }
        .search-one{
            width: 350px;
            height: 25px;
            line-height: 25px;
            outline: none;  /*获得焦点时  没有框体*/
            float: left;
            font-size:18px;  /*改变输入框内的文字大小的*/
        }
        .search-two{
            background-image: url(search-button.png);
            width: 29px;
            height: 29px;
            float: right;
            cursor: pointer;
        }
        .searchBox{
            position: absolute;
            top:300px;
            left:400px;
        }

        .suggest{
            background-color: #fff;
            width: 387px;
            border:1px solid #999;
        }
        .suggest ul{
            list-style: none;
        }
        .suggest ul li{
            padding: 3px;
            font-size: 14px;
            line-height: 25px;
            cursor: pointer;
        }
        .suggest ul li:hover{
            text-decoration: underline;
            background-color:#888888;
            color:#ffffff;
        }
    </style>
</head>
<body>
    <div>
        <div>
            <div></div>
            <form action="" id="search-form">
                <input type="text" id='search-input'class='search-one'/>
                <input type="submit" value=""/>
            </form>
        </div>
    </div>
    <div id='search-results-suggest' style='display:none;'>
        <ul id='search-result'>
            <li>121</li>
            <li>33</li>
            <li>44</li>
            <li>117</li>
            <li>116</li>
            <li>114</li>
            <li>131</li>
            <li>1131</li>
            <li>11123a</li>
        </ul>
    </div>
    <script>
    //封装几个常用函数
    var getDom = function(id){
        return document.getElementById(id);
    }
    //DOM 2级事件处理程序
    var addEvent = function(id,event,fn){
        var el=getDom(id)||document;
        if(el.addEventListener){
            el.addEventListener(event,fn,false);
        }else if(el.attachEvent){
            el.attachEvent('on'+event,fn);
        }
    }
    
    var getElementLeft = function(element){
        var actualLeft = element.offsetLeft;
        var current = element.offsetParent;

        while(current!==null){
            actualLeft += current.offsetLeft;
            current = current.offsetParent;
        }
        return actualLeft;
    }
    var getElementTop = function(element){
        var actualTop = element.offsetTop;
        var current = element.offsetParent;

        while(current!==null){
            actualTop += current.offsetTop;
            current = current.offsetParent;
        }
        return actualTop;
    }    

    // var ajaxGet = function(url,callback){
    //     var _xhr = null;
    //     if(window.XMLHttpRequest){
    //         _xhr = new window.XMLHttpRequest();
    //     }else if(window.ActiveXObject){
    //         _xhr = new ActiveXObject('Msxml2.XMLHTTP');
    //     }
    //     _xhr.onreadystatechange = function(){
    //         if(_xhr.readyState==4&&_xhr.status==200){
    //             callback(JSON.parse(_xhr.responseText));//条件达成 调用callback  顺便把服务器返回的响应主体文本用parse解析 JS才能识别
    //         }
    //     }
    //     _xhr.open('get',url,true);
    //     _xhr.send(null);
    // }

    var delegateEvent = function(target,event,fn){
        addEvent(document,event,function(e){
            if(e.target.nodeName == target.toUpperCase()){
                fn.call(e.target);
            }
        });
    }

    addEvent('search-input','keyup',function(){
        var searchText =getDom('search-input').value;//取到了用户输入的内容
        var request = new XMLHttpRequest();
        request.onreadystatechange =function(d){
            if(request.readyState==4 && request.status ==200){
                var d = d.AS.Results[0].Suggests;
                var html='';
            for(var i=0;i<data.length;i++){
                html+='<li>'+d[i].Txt+'</li>';
            }
            }
            getDom('search-result').innerHTML = html;
            getDom('search-results-suggest').style.position = 'absolute';
            getDom('search-results-suggest').style.display = 'block';
            getDom('search-results-suggest').style.top = getElementTop(getDom('search-form'))+38+'px';
            getDom('search-results-suggest').style.left = getElementLeft(getDom('search-form'))+'px';
        }
        request.open('GET','http://api.bing.com/qsonhs.aspx?q='+searchText,true);
        request.send();
    });

    delegateEvent('li','click',function(){
        var keyword = this.innerHTML;
        location.href = 'http://cn.bing.com/search?q='+keyword;
    });
    document.onclick = function(){
        getDom('search-results-suggest').style.display = 'none';
    }
    </script>
</body>
</html>

正在回答

1 回答

bing现在ajax直接返回了一段html代码

0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
搜索框制作
  • 参与学习       66041    人
  • 解答问题       431    个

本课程从简入深讲解搜索框的制作,学习JQ与JS实现Ajax技术的不同点

进入课程

源生JS 并没封装函数 火狐浏览器 为什么这不行呢?

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信