Jquery实现自动提示magicsuggest-min.js实例

1548年前 (2017-07-28)javaScript3229

效果图:


   1.引入外部js、css:

     <script src="${root!}/resource/js/plugins/magic_suggest/magicsuggest-min.js"></script>
     <link href="${root!}/resource/css/plugins/magic_suggest/magicsuggest-min.css" rel="stylesheet">


   2.html页面部分:

     <input type="text" class="form-control" id="scenic" name="model.F_SCENIC" placeholder="请选择景区" required="">


   3. js部分:

     var magic2 = null;
$(function() {
    getView('scenic', '003', '');   
});
function getView(id, STYLE, view) {
     magic2 = $("#"+id).magicSuggest({
        queryParam: 'searchText',
        minChars: '2',
        resultsField: 'list',
        queryParam: 'searchText',
        allowFreeEntries: false, //如果你不需要用户自已创建标签,则用这个
        displayField: 'P_NAME',
        valueField: 'P_ID',
        renderer:function(v){
            return '<div class="row"><div class="col-sm-5">'+v.P_NAME+'</div><div class="col-sm-7">'+v.P_ADDRESS+'</div></div>';
        }
    });

    $(magic2).on('expand',
        function(e, cb) {
            cb.setData('${root!}/admin/sys/poi/listName?sortName=P_NAME&P_STYLE=' + STYLE + '&view=' + view);
        });
    $(magic2).on('selectionchange',//选中一条记录后操作
           function(e, cb) {
                   $.post("${root!}/admin/sys/poi/setWeight?id="+cb.getValue(),function(data,status){
                         });//增加权重
           });                                                 
        

}


  4.后台类方法实现:


//多个pid 查询 对应名称
    public void listName() {
        PoiService svc = new PoiService();
        String view = getPara("view");
        System.out.println("view=="+getPara("view"));
        List list = new ArrayList();
                 renderJson(svc.list2(getPara("searchText"),getPara("P_STYLE"),view));
    }

PoiService类方法:

 public List list2(String searchTex,String P_STYLE,String view) {
        StringBuffer sqlBuffer  = new StringBuffer();
        StringBuffer where = new StringBuffer();
        List<Object> param = new ArrayList<Object>();
        System.out.println("searchTex==="+searchTex+"P_STYLE=="+P_STYLE);
        if(Tools.nullToSpace(searchTex).length()>0){
            where.append(" AND D.P_NAME LIKE ?");
            param.add("%" + searchTex + "%");
            
        }
        where.append(" AND D.P_STYLE = ?");
        param.add(P_STYLE);
        sqlBuffer.append("select * from(");
        //编辑时,查询已有的数据
        if(Tools.nullToSpace(view).length()>0){
            sqlBuffer.append("  SELECT D.P_ID,D.P_BDLNG,D.P_BDLAT ,D.P_NAME,P_ADDRESS,P_TELEPHONE," +
                    "P_TYPE,P_AREAID,P_WEIGHT FROM T_SYS_POI D WHERE D.P_ID IN ("+view+") UNION "
                            + "");// ORDER BY D.P_WEIGHT DESC
        }
        //添加时候,按权重查询
        sqlBuffer.append("select * from(");
            sqlBuffer.append("SELECT D.P_ID,D.P_BDLNG,D.P_BDLAT ,D.P_NAME,P_ADDRESS,P_TELEPHONE," +
                    "P_TYPE,P_AREAID,P_WEIGHT FROM T_SYS_POI D where 1=1 "  + where.toString()
                            + " order by D.P_WEIGHT DESC) WHERE ROWNUM <= 25 )");
        
    
        System.out.println("sqlBuffer.toString()==="+sqlBuffer.toString());
        List<T_SYS_POI> list = T_SYS_POI.dao.find(sqlBuffer.toString(),param.toArray() );
        return list;
    }

本文原创,转载必追究版权。

分享给朋友:

相关文章

每次开机checking file system on d

 解决方案:点击左下角(开始)- (运行)输入(CMD)回车 - 进入CMD界面- 输入(d:)回车 - 输入(chkdsk /f)中间有空格。回车,出现提示按Y键,完成后,重启一次会检...

freeMarker 截取字符串(操作字符串函数 )

<#if c.proSummary!?length gt 25>  <!-- 如果长度 >25 截取25个字-->    ...

freemarker 判断日期变量为空处理 及InvalidReferenceException异常处理

at freemarker.core.InvalidReferenceException.getInstance(InvalidReferenceException.java:98);InvalidR...

太阳的后裔 经典对白(羞羞哒)

太阳的后裔 经典对白(羞羞哒)

关于电视剧 ,小编常说早就戒了,但是好剧呢还是要追滴。太阳的后裔, 追剧追到12集了,开始都是宋仲基比较调皮:我很想问你一件事情。什么都不要问,你知道我要问什么。看你现在一脸都是很想嘲笑我的表情。哪有...

谈话让别人舒服的程度,决定你成功的高度

谈话让别人舒服的程度,决定你成功的高度

职场上,有这样两种截然相反的人:有人生怕别人舒服,尽量让别人不舒服,而只要自己舒服就行;还有一类人生怕别人不舒服,尽量让别人舒服,哪怕委屈自己。猎头公司猎聘的老总有几十万年薪的,也有几百万的,甚至有过...

MyEclipse 中项目修改SVN的地址

MyEclipse 中项目修改SVN的地址

在工作环境调整时,有的时候SVN服务器的地址需要修改,而正在开发中的项目在Eclipse中有些代码没有提交,此时怎么修改SVN的地址呢?以下有一个简单的办法:一、在MyEclipse中选择Window...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。