用jsonp实现搜索框功能的实现

用jsonp实现搜索框功能的实现

前面的话:

在上周本来想发一篇模仿必应搜索的界面。但是在准备写文章之前突然想到前面学习了ajax技术,在这里我也让我的页面有一种不需要手动刷新就能获取到数据。但是发现用前面的方法并不能获取到我想要的效果。无奈前几天电脑换系统,把之前的源码丢了(前面有个不好的习惯就是把最近在做的东西放桌面)。今天想彻底把这个问题搞明白。

用jquery和ajax进行初步的尝试:

(本代码是参考慕课网,搜索框制作视频制作,有关具体详情请参考视频。自己之前的代码找不到了,之前最先的想法也是来自那里,所以这次直接用那里的代码)
html代码:

    <div class="bg-div">
        <div class="search-box">
            <div class="logo"></div>
            <form id="search-form">
                <input type="text" class="search-input-text" autocomplete="off" name="q" id="search_input" />
                <input type="submit" class="search-input-button" value="" id="search_submit">
            </form>
        </div>
    </div>  

    <div class="suggest" id="search-suggest" <!--style="display:none;"-->>
        <ul id="search-result">
            <li>搜索结果1</li>
            <li>搜索结果2</li>
        </ul>
    </div>  

css代码:

* {
    padding: 0;
    margin: 0;
}  

body {  

}  

.bg-div{
    background-image: url(‘images/river.jpg‘);
    width: 1228px;
    height: 690px;
    margin: 0 auto;
    position: relative;
}  

.logo {
    background-image: url(‘images/logo.png‘);
    width: 107px;
    height: 53px;
    float: left;
    margin: -4px 18px 0 0;
}  

form {
    float: left;
    background-color: #fff;
    padding: 5px;
}  

.search-input-text {
    border: 0;
    float: left;
    height: 25px;
    line-height: 25px;
    outline: none;
    width: 350px;
    font-size: 16px;
}  

.search-input-button {
    border: 0;
    background-image: url(‘images/search-button.png‘);
    width: 29px;
    height: 29px;
    float: left;
}  

.search-box {
    position: absolute;
    top: 200px;
    left: 300px;
}  

#search-suggest {
    width: 388px;
    background-color: #fff;
    border: 1px solid #999;
    display: none;
}  

.suggest ul {
    list-style: none;
}  

.suggest ul li {
    padding: 3px;
    font-size: 14px;
    line-height: 25px;
    cursor: pointer;/*手型*/
    /*这段代码去掉
    position:absolute;
    left:----px;
    top:----px;
     */
}  

.suggest ul li:hover {
    text-decoration: underline;
    background-color: #e5e5e5;
} 

用jquery来实现效果:

在这之前,我们基本上得到了我们想要的图形效果,但是我们在搜索框内输入想要查询的内容这时候是不会有效果的(一般的搜索框效果都是在键盘输入的时候,下面会显示一部分与之关联的关键搜索信息,然后鼠标移动上去点击后会跳到相应链接)。为了一步步验证我们的思路,我们这里修改一下之前的代码,

1、将li标签中的定位去掉;2、在html中将li标签设置为隐藏。然后我们进行后面的操作。

思考一:如何在键盘输入的时候就显示相关信息(即:li标签中的内容)?

思路:我们先引入jquery,然后文档加载完后执行一个键盘事件,然后在键盘事件中改变相应的css效果

$(function() {
    //键盘事件
    $("#search_input").bind("keyup", function() {
                $("#search-suggest").show().css({
                    top : $("#search-form").offset().top + $("#search-form").height()+10,
                    left : $("#search-form").offset().left,
                    position : "absolute",
                });
    });
});

这时候,我们在搜索框中输入内容时,下面会跟着显示对应的搜索(模拟)

思考二:如何实现鼠标点击搜索按钮的时候,会搜索相应的内容?

思路:用鼠标点击事件,让鼠标点击后设置一个地址,点击后直接跳到相应地址,代码实现:

    //事件代理  --》鼠标点击事件
    $(document).delegate("li", "click", function() {
        var keyword = $(this).text();
        location.href = "http://cn.bing.com/search?q=" + keyword;
    });

思考三:我们如何在搜索框输入数据时,下面会提示相关搜素信息?
思路:我们我们用jquery中的get去实现,参考代码:

        var searchText = $("#search_input").val();
        $.get( "http://api.bing.com/qsonhs.aspx?q="+searchText , function(data) {
                console.log(data);
                var d = data.AS.Results[0].Suggests;
                var html = "";
                for(var i = 0; i < d.length; i++) {
                    html += "<li>"+d[i].Txt+"</li>";
                }
                $("#search-result").html(html);
            }
            , "json");

到这里,按理来说我们这里应该可以得到我们想要的结果了,但是,找了好久都没有发现哪里错了。视频里面接着描述了用JSONP来进行跨域操作,但是我也按视频中的操作,始终得不到我想要的结果,于是我埋头去看《javascript高级程序设计》,去找关于jsonp的用法

关于jsonp:

关于jsonp,《javascript高级程序设计》一书中介绍的比较少,下面是我看了之后的归纳。
    jsonp的全写是 json with padding,其出现是为了解决各主浏览器的之间的同源策略的问题,一般来说ServerA 域下面的页面是没有办法与非 ServerA 下面的资源进行沟通,而 Html 的<script>元素是个例外,利用 <script> 这个开源策略,网页可以从其他来源动态获取 json数据,而这种模式就是所谓的 JSONP,用 jsonp 抓到并不是真正意义上 的 json 而是任意的 javascript ,它是直接通过 javascript 编译器编译而不是 json 解释器。更多关于json的知识请点击:http://www.cnblogs.com/foodoir/p/5894760.html查看
    
既然书上没有写,那就去网上搜索资源。这里截取一段和文章前面有关的信息的代码:

        $.ajax({
             type: "get",
             async: false,
             url: "http://flightQuery.com/jsonp/flightResult.aspx?code=CA1998",
             dataType: "jsonp",
             jsonp: "callback",//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(一般默认为:callback)
             jsonpCallback:"flightHandler",//自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名,也可以写"?",jQuery会自动为你处理数据
    success: function(json){
                 alert(json.price +  json.tickets + ‘ 张。‘);
             },
             error: function(){
                 alert(‘fail‘);
             }
         });

通过这段代码来修改我们自己的代码:

       $.ajax({
            type: "GET",
            url: "http://api.bing.com/qsonhs.aspx?type=cb&q=" + searchText,
            dataType: "jsonp",
            jsonp: ‘cb‘,
            success: function(data) {
                var d = data.AS.Results[0].Suggests;
                var html = "";

                for(var i = 0; i < d.length; i++) {

                    html += "<li>" + d[i].Txt + "</li>";
                }
                $("#search-result").html(html);

                $("#search-suggest").show().css({
                    top: $("#search-form").offset().top + $("#search-form").height() + 10,
                    left: $("#search-form").offset().left,
                    position: "absolute",
                });
            }
        })

更多思考:我们可以在前面增加一些判断,让我们的效果实现起来更完美

                if(data == null) {
                    $("#search-suggest").hide();
                    return false;
                }
                if(data.AS == null) {
                    $("#search-suggest").hide();
                    return false;
                }
                if(data.AS.Results == null) {
                    $("#search-suggest").hide();
                    return false;
                }
                if(data.AS.Results[0] == null) {
                    $("#search-suggest").hide();
                    return false;
                }
                if(data.AS.Results[0].Suggests == null) {
                    $("#search-suggest").hide();
                    return false;
                }   

经过测试前面的代码,发现还有不足,进一步修改代码:

    $("#search-form").submit(function() {
        var keyword = $("#search_input").val();
        console.log("word=" + keyword);
        //if (keyword == null) {return false;}
        location.href = "http://cn.bing.com/search?q=" + keyword;
    });

到这里,我们的效果差不多就出来了,效果截图:

源代码已托管至:http://sandbox.runjs.cn/show/gfdpkysk,点击即可查看。

后面的话:

  这些天学习的新东西挺多的,现在有一个想法就是把最近学的东西把它串联起来,做一个综合的效果。参考必应网站,真的有好多东西已经可以做出来了,接下来的一段时间就好好的把自己想要做的效果实现好。

时间: 2024-12-23 07:44:39

用jsonp实现搜索框功能的实现的相关文章

iOS开发——UI篇OC篇&amp;TextField作为搜索框的使用

TextField作为搜索框的使用 在iOS开发中我们经常会使用到搜索框,但是有的时候系统自带的搜索框不足以满足我吗想要的功能,这个时候我们就可以使用自定义的搜索框实现想要的功能. 今天就简单的介绍一下怎么去使用UITextField实现一个搜索框,当然如果你有更好的方法也可以分享出来,大家相互学习. 一:直接使用 1 UITextField *text = [[UITextField alloc] init]; 2 text.frame = CGRectMake(0, 0, 320, 30);

js搜索框实现自动搜索功能

做项目的时候,老板让我自己封装一个搜索功能,就类似于百度这种 输入了字符之后,就可以自动搜索数据,而且还会出现一个下拉框供用户选择,我觉得我老板有问题,网上有这么多插件,不仅封装好了,性能也做了优化,什么功能都有,他不用,一定要我用原生js写,写毛线写,我内心吐槽了很久,不过还是要做,为了工资而低头,所以我这个小白就硬着头皮写完了,肯定有很多不足,也没有封装,就是想到哪里写到哪里,给大家当反面教材看看,如果大家看见了,也可以指点指点我,让我进步 由于我是在项目里写的,所以有很多东西和大家的肯定不

站长工具|百度搜索框提示功能

百度向站长开放免费“百度搜索框”代码和“百度搜索框提示”代码.只需进行简单的设置, 即可将“ 百度搜索框( 带提示功能)”功能快速加入到您的网页中.提升用户在网站中的搜索体验. 根据不同类型的网站需求,站长工具一共提供三种引入方式供您选择: 简单方式——方便的将“百度搜索框(带提示功能)”直接加入到您的网页中.将以下代码加入到您的网页中,即可获得带有“搜索框提示”功能的百度搜索框 HTML代码: <form action=”http://www.baidu.com/baidu” target=”

java简单的实现搜索框的下拉显示相关搜索功能

最近做了一个简单的搜索框下面下拉显示相关搜索的功能,有点模仿百度的下拉展示相关搜索 先上个展示图 : 点击进入演示地址,大家可以输入长点的搜索,点击搜索,再输入之前搜索词的前面部分,看是否能展示出来 搜索框相关搜索的展示很简单,就是根据你的搜索词,去数据库中匹配,是否有类似的搜索词存在,按照搜索词被搜索的次数进行排序显示出来 我设计的是每次搜索一个词,提交之后都会去数据库进行查询,看是否存在这个搜索词的搜索,若存在,则对数据库中的这个搜索词对象进行次数加1,不存在,则创建这个新搜索词对象,保存在

Android中的搜索框(SearchView)的功能和用法

1.SearchView是搜索框组件,它可以让用户在文本框里输入文字,通过监听器取得用户的输入,当用户点击搜索时,监听器执行实际的搜索. 2.SearchView组件的常用方法如下: ①setIconifiedByDefault(boolean iconified) ===> 设置搜索框默认是否自动缩小为图标. ②setOnQueryTextListener(SearchView,OnQueryTextListener listener) ===> 为搜索框设置监听器 ③setSubmitBu

使用jQuery-UI来实现一个Ajax的自动完成功能(自动填充搜索框的下拉值)

首先你要在.net拓展包中去搜索  jquery ui (Combined Libray)安装这么个文件 第二部   在控制器中添加我们根据输入搜索框的值获取符合的记录集的action 第三步  有了数据集,就该去画我们的页面了 第四步  修改我们的js文件 具体效果就是这样的 如图:(不知道为什么我的ui样式有点丑) 但是这样 还需要选择某一项,再点击搜索,很繁琐的...我们想实现选中之后 直接得到搜索页 第五步  再次修改我们的js文件 这样就实现了你一选,然后就出现了搜索结果,一步到位.

使用jquery+ajax+php实现搜索框的功能

搜索框的原理: 客户端:输入要搜索的关键字于文本框,然后文本框将关键字获取,使用ajax发送请求到服务端,然后根据服务端返回来的信息显示到一个div中 服务端:接收传过来的数据,然后在数据库中搜索,再返回数据给客户端 首先是客户端 新建一个输入框 <input type="text" id="keyword" name="keyword" /> 在输入框的下面创建一个div,先让他隐藏起来 <div id="searc

实现搜索框跟随鼠标悬停菜单功能

先上效果图: 关键点只有一个:获取鼠标悬停点位置. event.clientX 设置或获取鼠标指针位置相对于当前窗口的 x 坐标,其中客户区域不包括窗口自身的控件和滚动条. event.clientY 设置或获取鼠标指针位置相对于当前窗口的 y 坐标,其中客户区域不包括窗口自身的控件和滚动条. event.offsetX 设置或获取鼠标指针位置相对于触发事件的对象的 x 坐标. event.offsetY 设置或获取鼠标指针位置相对于触发事件的对象的 y 坐标. event.screenX 设置

Android零基础入门第62节:搜索框组件SearchView

原文:Android零基础入门第62节:搜索框组件SearchView 一.SearchView概述 SearchView是搜索框组件,它可以让用户在文本框内输入文字,并允许通过监听器监控用户输入,当用户输入完成后提交搜索时,也可通过监听器执行实际的搜索. SearchView默认是展示一个search的icon,点击icon展开搜索框,也可以自己设定图标.用SearchView时可指定如下表所示的常见XML属性及相关方法. 如果为SearchView增加一个配套的ListView,则可以为Se