推广 热搜: 公司  快速  上海  中国    未来  企业  政策  教师  系统 

[转]怎么样把百度搜索引入自己的网站JS实现(附源代码)

   日期:2024-12-07     作者:wc3tru    caijiyuan   评论:0    移动:http://keair.bhha.com.cn/mobile/news/4146.html
核心提示:[转]怎么样把百度搜索引入自己的网站JS实现(附源代码)自己的from http://www.cnblogs.com/sufei/archive/2011/12/19/2293289.htm
[转]怎么样把百度搜索引入自己的网站JS实现(附源代码) 自己的

from http://www.cnblogs.com/sufei/archive/2011/12/19/2293289.html

[转]怎么样把百度搜索引入自己的网站JS实现(附源代码)

大家都见过这种效果吧

怎么样把他引入到自己的网站里面呢?下面咱们一起来分析一下吧

使用Ie9的”开发工具“可可以轻松获取到,在你输入一个关键字时百度是怎么获取智能提示,就是相关的关键字的。

一起来看一下吧

大家可以清楚的看到在我们每次修改查询框时,百度就是发一个Ajax请求去调相应的数据

地址就是:http://suggestion.baidu.com/su?wd=博客&p=3&cb=window.bdsug.sug&t=1324271669786

大家不难看出来吧,wd=博客 这个博客 就是我输入的关键字,如果你想使用其它的关键字的话,只需要动太的修改wd的值就行了。

这时大家一定会这样想,我们是不是只要发一个Get请求,只要每次在我们自己的网站上查询时动态的发一个Ajax请求去访问这个地址就行了呢?是的,

但大家一个不要傻着去使用Http请求,因为这样的请求是从你的服务器发起的,当然百度肯定是会封你的。

我们需要怎么做才能避免这个问题呢?

那就只有一个方法了,使用Js,在客户端执行请求。因为Js是在客户端发起的,就算是百度封的话,那它封的是所有过量使用你网站的用户,相信百度不会傻到这点上吧。因为这样他们失去很多用户

所以这个方法应该 是成立的

但是大家都知道Js是不能跨越访问的,而百度又不可能给你跨越的接口,或者是权限,我们应该怎么办呢?

简单,我们上面也看到了,Baidu给我们的是一个Jsonp的数据格式,那么我们就可以直接使用Jsonp的方法去发起Ajax请求了,因为返回Jsop格式数据的JS是可以跨越访问的

大家一起来看下我的代码吧。

代码很简单大家一看应该就明白了,我只解释一下这句吧

wd是我们要输入的关键字。

p  和就不用管了

cb是什么呢?是Ajax返回是直接调用的方法,个是百度返回的数据里面会执行方法进行调用,我们不用做任何的处理

只需要写一个方法接受数据就行了

urls 这个就是我们需要的数据,我们一起来看看调用后返回的数据是什么样式的吧

这就是百度返回的数据,我们只需要s后面的数据就行了,现在应该明白我写var urls = strurls["s"]; 这句的意思了吧。

在个时候大家可以自己试试了。

因为百度只返回的数据,所以我们还要做一个智能提供的框,当然也就可以自己定义样子了。先来看看这个框吧

样式如下

方法如下

这个方法这句 if ($(this)[0].getAttribute('url') == 'true') {//给所有的url=true属性的Text加效果

的意思是,我们所有引用这个网页的Text框中,只要有一个属性是url='true'的都会实现这个效果,也就是说我们只要把样式和Js文件引入一下,然后想让那具控件显示就直接添加一个属性

url='true'就行了,别的什么也不需要做了。是不是很方便啊。

一起来看看绑定方法的实现吧

下面是整个Js文件(这里还包括一个同时输入多个文本框的效果)

网页代码如下:

好了我们一起浏览一下效果吧

是不是很拉风啊。

说到这里不仅仅是百度这样,像Soso,Sogou等都可以使用同样的方法来实现。

大家如有兴趣的话可以下载这个例子看看。下载地址:http://download.csdn.net/detail/sufei1013/3949230

本文地址:http://keair.bhha.com.cn/news/4146.html    康宝晨 http://keair.bhha.com.cn/ , 查看更多

特别提示:本信息由相关用户自行提供,真实性未证实,仅供参考。请谨慎采用,风险自负。

 
 
更多>同类最新资讯
0相关评论

文章列表
相关文章
最新动态
推荐图文
最新资讯
点击排行
网站首页  |  关于我们  |  联系方式  |  使用协议  |  版权隐私  |  网站地图  |  排名推广  |  广告服务  |  积分换礼  |  网站留言  |  RSS订阅  |  违规举报  |  粤ICP备2023022329号