zoukankan      html  css  js  c++  java
  • [easyUI] autocomplete 简单自动完成以及ajax从服务器端完成

      通过id取input标签对象,调用autocomplete方法

    <script>
        var sources = [
                "ActionScript",
                "AppleScript",
                "Asp",
                "COBOL",
                "ColdFusion",
                "Erlang",
                "Fortran",
                "Groovy",
                "Haskell",
                "Java",
                "JavaScript",
                "Lisp",
                "Perl",
                "PHP",
                "Python",
                "Ruby",
                "Scala",
                "Scheme"
              ]; 
        $(function() {
            $( "#tags" ).autocomplete({
                source:sources
            });
        });
    </script>
    <body>
        <div class="ui-widget">
            <h2>查询:<input id="tags"></h2>
        </div>
    </body>

    {source:sources}将多个sources的String类型数组,包装成JSON.

    Ajax服务器端完成:

    服务器端网页的Java代码,也只有java代码.

        String query = request.getParameter("term");//获取要匹配的参数
        String[] sources = {"ActionScript",
                "AppleScript",
                "Asp",
                "BASIC",
                "C",
                "C++",
                "Clojure",
                "COBOL",
                "ColdFusion",
                "Erlang",
                "Fortran",
                "Groovy",
                "Haskell",
                "Java",
                "JavaScript",
                "Lisp",
                "Perl",
                "PHP",
                "Python",
                "Ruby",
                "Scala",
                "Scheme"};
        StringBuilder builder = new StringBuilder("[");
        for(int i=0;i<sources.length;i++){//遍历目标数组,返回符合条件的结果
            if(null != query){
                if(sources[i].indexOf(query) >= 0){//表示如果输入了query,sources[i]的String包含String query
                    builder.append("{"label":""+sources[i]+""},");//拼接成{"label":sources[i]}的JSON数据
                }
            }else{//如果不输入query,返回所有的sources[i]成为JSON数组.
                builder.append("{"label":""+sources[i]+""},");
            }
        }
        String result = builder.toString();//转换为字符串.
        if(result.endsWith(",")){//因为拼接的结果转换成字符串后,数组内会多出","
            result = result.substring(0,result.length()-1);//需要截去最后一个逗号.
        }
        result+="]";//拼接"]"
        out.print(result);
        
    View Code

    script:

        $(function() {
            $( "#tags" ).autocomplete({
                source:function(request,response){
                //request.term估计是将input内容提交后的字符串."term='字符串'",其实等价于传入一个
                //{"term":"字符串"}的JSON数据. 具体在jQuery1.11.10的帮助文档中有所描述,搜get第二个即是.
                    $.get("server/demo4_server.jsp","term="+request.term,function(data){
                    //url(目标地址),data(传入数据),callback(回调函数)
                        var result = $.parseJSON(data);
                        response(result);// 输出返回结果
                    });
                }
            });
        });
    View Code

    parseJSON(String strJSON)函数:

    宛如智障,暗藏锋芒
  • 相关阅读:
    TCP 的那些事儿(转载)
    3. 对象在内存中的布局
    GO语言学习之数据类型-->基本类型(字符串)
    GO语言学习之变量and常量
    wrk
    为什么显示消息“错误:您所在国家/地区是禁运国,无法下载 Java”?
    raw.githubusercontent.com 访问不了
    Windows Terminal
    vue:无法加载文件C:UsersAppDataRoaming pmvue.ps1, 在此系统上无法加载脚本
    vue使用过滤改变el-switch开关的状态
  • 原文地址:https://www.cnblogs.com/zienzir/p/9221193.html
Copyright © 2011-2022 走看看