9

我是 jqgrid 的新手,我发现有四种方法可以在 jqgrid 中实现搜索:

a toolbar searching
a custom searching
a single field searching
a more complex approach involving many fields and conditions - advanced searching

我想知道是否可以实现一种“谷歌风格”的通用搜索,在这种情况下,您只有一个文本字段用于搜索查询。如果我要在该字段中写入一些内容,它会尝试从网格中的所有数据中进行搜索。

编辑:我想一次获取所有数据并使用搜索该本地数据集。

见附图。

在此处输入图像描述

4

2 回答 2

18

有很多方法可以实现这样的要求。我准备了两个演示,演示了一个可能的解决方案:第一个下一个。第二个演示是第一个演示的增强版,我使用高亮 jQuery 插件的方式与我在此处描述的方式相同。

首先,我将带有按钮的输入框添加到网格的顶部工具栏。我用来toolbar: [true, "top"]在网格顶部添加一个空工具栏。然后我使用下面的代码

$('#t_' + $.jgrid.jqID($grid[0].id))
    .append($("<div><label for=\"globalSearchText\">Global search in grid for:&nbsp;" +
        "</label><input id=\"globalSearchText\" type=\"text\"></input>&nbsp;" +
        "<button id=\"globalSearch\" type=\"button\">Search</button></div>"));

用 HTML 片段填充工具栏

<div>
    <label for="globalSearchText">Global search in grid for:&nbsp;</label>
    <input id="globalSearchText" type="text">&nbsp;
    <button id="globalSearch" type="button">Search</button>
</div>

要开始搜索,我使用了以下 JavaScript 代码

$("#globalSearchText").keypress(function (e) {
    var key = e.charCode || e.keyCode || 0;
    if (key === $.ui.keyCode.ENTER) { // 13
        $("#globalSearch").click();
    }
});
$("#globalSearch").button({
    icons: { primary: "ui-icon-search" },
    text: false
}).click(function () {
    var rules = [], i, cm, postData = $grid.jqGrid("getGridParam", "postData"),
        colModel = $grid.jqGrid("getGridParam", "colModel"),
        searchText = $("#globalSearchText").val(),
        l = colModel.length;
    for (i = 0; i < l; i++) {
        cm = colModel[i];
        if (cm.search !== false && (cm.stype === undefined || cm.stype === "text")) {
            rules.push({
                field: cm.name,
                op: "cn",
                data: searchText
            });
        }
    }
    postData.filters = JSON.stringify({
        groupOp: "OR",
        rules: rules
    });
    $grid.jqGrid("setGridParam", { search: true });
    $grid.trigger("reloadGrid", [{page: 1, current: true}]);
    return false;
});

$grid我们开始搜索的网格在哪里 ( ) var $grid = $("#list");

为了提高顶部工具栏中元素的可见性,我使用了这样简单的附加 CSS

.ui-jqgrid .ui-userdata { height: auto; }
.ui-jqgrid .ui-userdata div { margin: .1em .5em .2em;}
.ui-jqgrid .ui-userdata div>* { vertical-align: middle; }

结果如下图所示

在此处输入图像描述

第二个演示使用 higlighting 插件来提高网格的可见性,以便用户立即看到在行中找到搜索字段的位置:

在此处输入图像描述

可以看到,在创建搜索过滤器期间,我跳过了具有search: false属性(如"note"列)的列和具有stype: "select". 我"cn"在所有列中都使用了(包含)过滤器。

于 2013-11-01T13:59:33.187 回答
4

是的,这是可能的——我可能会补充说非常简单。只需在网格上方(或您想要的任何位置)放置一个文本框:

<input type="text" id="search-string" name="search-string" />

还有一个搜索按钮:

<a href="#" id="search-button">Search</a>

这是该按钮的单击事件所需的 jQuery:

$("#search-button").button().click(function(){
    searchString = $.trim($("#search-string").val());

    // check to see a search term has been entered in the textbox
    if(searchString == ""){
        alert("Please enter a word or phrase before searching!");
        // reset search box value to empty
        $("#search-string").val("").focus();
    }
    else{
        // set your grid's URL parameter to your server-side select file (that queries the DB)
        // we pass one parameter - the search string from the textbox
        $("#your-grid").jqGrid('setGridParam',{url:'crud/full-text-search.php?searchString='+searchString});
        // This line may need to be changed (if you use XML instead of JSON) 
        // It will reload the grid, using the new URL with the search term parameter
        $("#your-grid").jqGrid('setGridParam',{datatype:'json'}).trigger('reloadGrid');  
    }
});

当然,在查询数据库的服务器端文件中,您需要获取包含搜索字符串的 URL 参数,并使用正确的WHERE子句构建查询......

于 2013-10-29T14:48:49.243 回答