ajax实现百度搜索输入动态获取数据

这篇博客通过Ajax技术实现在输入框中输入时,动态从服务器获取并展示数据,模仿百度搜索的功能。主要涉及HTML页面布局、样式设计及JavaScript代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这里简单的利用ajax原理来模拟百度的搜索,实现边输入边动态的获取服务器的数据。

1、HTML页面布局

<html>
     <head>
    <meta charset="UTF-8">
    <title></title>
      </head>
     <body>
         <input type="text" name="txt" id="txt" value="" />
         <ul id="ul">
         </ul>
      </body>
</html>

2、style样式页面

<style>
input{
    width: 300px;
    height: 30px;
}
ul{
    list-style: none;
    width: 300px;   
    padding: 0;
    margin:0;
    border: 1px solid #ccc;     
    display: none;          
    }
ul li{
    list-style: none;
    width: 300px;
    height: 30px;
    line-height: 30px;      
    }
ul li a{
    display: block;
    color: #333;
    text-decoration: none;
}
ul li a:hover{
    background: #ccc;
}
</style>

3、javascript代码

<script>
function fn(data){
    console.log(data)
    var oUl=document.getElementById('ul');
    var arr=data.s;         
    var html="";
    for(var i=0;i<arr.length;i++){              
    html+='<li><a href="https://www.baidu.com/baidu?tn=monline_3_dg&ie=utf-8&wd='+arr[i]+'" target="_blank">'+arr[i]+'</a></li>';
    }
    oUl.innerHTML=html;
}
</script>
<script>
    window.onload=function(){
    var oUl=document.getElementById('ul');
    var oTxt=document.getElementById('txt');
    var oHead=document.getElementsByTagName('head')[0];
    oTxt.onkeyup=function(){    
    var oS=document.createElement('script');//动态添加script标签
    oS.src='https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd='+oTxt.value+'&cb=fn';//从百度获取的接口数据
    oHead.appendChild(oS);
    if(oTxt.value!=''){ 
        oUl.style.display='block';
    }else{
        oUl.style.display='none';
        }
    }

}
</script>
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值