Проблема с использованием функции поиска jqGrid - PullRequest
1 голос
/ 09 февраля 2011

Я новичок в jqgrid, но очень хочу разобраться с этим. Мне трудно заставить работать функцию поиска. Вот XML, с которым я работаю:

<?xml version='1.0' encoding='utf-8'?>
<rows>
    <page>1</page>
    <total>1</total>
    <records>3</records>
        <row id='1'>
            <cell>1</cell>
            <cell>5 Little Roodee</cell>
            <cell>Hawarden</cell><cell>CH5 3PU</cell>
            <cell>895.00</cell>
            <cell>1</cell>
        </row>
        <row id='2'>
            <cell>2</cell>
            <cell>28 Pant-y-Fawnog</cell>
            <cell>Buckley</cell>
            <cell>CH7 2PD</cell>
            <cell>610.00</cell>
            <cell>0</cell>
        </row>
        <row id='3'>
            <cell>3</cell>
            <cell>60 Langford Crescent</cell>
            <cell>Buckley</cell>
            <cell>CH7 2PR</cell>
            <cell>625.00</cell>
            <cell>1</cell>
        </row>
</rows>

Как видите, все довольно просто. Теперь вот объявление jqgrid, которое я использую:

$(function(){ 
          $("#list").jqGrid({
            url:'xml_properties_jq.php',
            datatype: 'xml',
            mtype: 'GET',
            colNames:['ID','Address', 'Town','Postcode','Rent. Val','Active'],
            colModel :[ 
              {name:'property_id', index:'property_id', width:40}, 
              {name:'property_add_1', index:'property_add_1', width:150}, 
              {name:'property_add_town', index:'property_add_town', width:80, align:'right', searchoptions: { sopt: ['eq', 'ne']}}, 
              {name:'property_add_postcode', index:'property_add_postcode', width:80, align:'right'}, 
              {name:'property_rentable_value', index:'property_rentable_value', width:80, align:'right'}, 
              {name:'property_active', index:'property_active', width:60}
            ],
            pager: '#pager',
            rowNum:10,
            rowList:[10,20,30],
            sortname: 'property_id',
            sortorder: 'desc',
            viewrecords: true,
            caption: 'Properties'
          })
          //jQuery("#list").jqGrid('navGrid','#pager',{edit:false,add:false,del:false});
          .navGrid('#pager',{view:true, del:false}, 
{}, // use default settings for edit
{}, // use default settings for add
{},  // delete instead that del:false we need this
{multipleSearch : false}, // enable the advanced searching
{closeOnEscape:true} /* allow the view dialog to be closed when user press ESC key*/
);
}); 

Наконец, вот PHP, который создает мой XML:

<?php 
//include the information needed for the connection to MySQL data base server. 
// we store here username, database and password 
include("Connections/db.php");

// to the url parameter are added 4 parameters as described in colModel
// we should get these parameters to construct the needed query
// Since we specify in the options of the grid that we will use a GET method 
// we should use the appropriate command to obtain the parameters. 
// In our case this is $_GET. If we specify that we want to use post 
// we should use $_POST. Maybe the better way is to use $_REQUEST, which
// contain both the GET and POST variables. For more information refer to php documentation.
// Get the requested page. By default grid sets this to 1. 
$page = $_GET['page']; 

// get how many rows we want to have into the grid - rowNum parameter in the grid 
$limit = $_GET['rows']; 

// get index row - i.e. user click to sort. At first time sortname parameter -
// after that the index from colModel 
$sidx = $_GET['sidx']; 

// sorting order - at first time sortorder 
$sord = $_GET['sord']; 

// if we not pass at first time index use the first column for the index or what you want
if(!$sidx) $sidx =1; 

// connect to the MySQL database server 
//$db = mysql_connect($dbhost, $dbuser, $dbpassword) or die("Connection Error: " . mysql_error()); 

// select the database 
//mysql_select_db($db) or die("Error connecting to db."); 
mysql_select_db($database_eazylet, $eazylet);

// calculate the number of rows for the query. We need this for paging the result 
$result = mysql_query("SELECT COUNT(*) AS count FROM p_properties", $eazylet); 
//$row = mysql_fetch_array($result,MYSQL_ASSOC); 
$row = mysql_fetch_assoc($result);
$count = $row['count']; 

// calculate the total pages for the query 
if( $count > 0 && $limit > 0) { 
              $total_pages = ceil($count/$limit); 
} else { 
              $total_pages = 0; 
} 

// if for some reasons the requested page is greater than the total 
// set the requested page to total page 
if ($page > $total_pages) $page=$total_pages;

// calculate the starting position of the rows 
$start = $limit*$page - $limit;

// if for some reasons start position is negative set it to 0 
// typical case is that the user type 0 for the requested page 
if($start <0) $start = 0; 

// the actual query for the grid data 
$SQL = "SELECT * FROM p_properties ORDER BY $sidx $sord LIMIT $start , $limit"; 
$result = mysql_query($SQL, $eazylet) or die("Couldn't execute query.".mysql_error()); 

// we should set the appropriate header information. Do not forget this.
header("Content-type: text/xml;charset=utf-8");

$s = "<?xml version='1.0' encoding='utf-8'?>";
$s .=  "<rows>";
$s .= "<page>".$page."</page>";
$s .= "<total>".$total_pages."</total>";
$s .= "<records>".$count."</records>";

// be sure to put text data in CDATA
while($row = mysql_fetch_array($result,MYSQL_ASSOC)) {
//while($row = mysql_fetch_assoc($result)) {
    $s .= "<row id='". $row['property_id']."'>";            
    $s .= "<cell>". $row['property_id']."</cell>";
    $s .= "<cell>". $row['property_add_1']."</cell>";
    $s .= "<cell>". $row['property_add_town']."</cell>";
    $s .= "<cell>". $row['property_add_postcode']."</cell>";
    $s .= "<cell>". $row['property_rentable_value']."</cell>";
    $s .= "<cell>". $row['property_active']."</cell>";
    $s .= "</row>";
}
$s .= "</rows>"; 

echo $s;
?>

Вся сортировка отлично работает в сетке, поэтому я предполагаю, что данные в порядке.

Моя проблема в том, что когда я нажимаю кнопку поиска, введите любые действительные критерии (т. Е. ID = 1) и нажмите НАЙТИ, ничего не происходит. Поле поиска остается, и список не был отфильтрован.

Я работал над этим весь день безуспешно, поэтому любая помощь была бы ОЧЕНЬ с благодарностью получена !!

Я использую jquery v1.4.4 и jqgrid v3.8.2

Большое спасибо всем

Si

1 Ответ

1 голос
/ 09 февраля 2011

Зависит от того, какой тип поиска , который вы используете на сервере, получает различные дополнительные параметры.

В случае поиска по одному полю это будет параметр searchField, searchString и searchOper. В случае предварительного поиска каждый имеет один параметр filters, который имеет в JSON-кодированную форму информацию обо всех параметрах поискового запроса. В случае поиска на панели инструментов и дополнительного параметра stringResult:true формат параметров такой же, как и в случае расширенного поиска .

Так что вам просто нужно добавить свой код с анализом параметров поискового запроса. Вы можете загрузить демонстрационные файлы со страницы загрузки jqGrid и просмотреть, например, код файла search_adv.php.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...