Jqgrid + CodeIgniter - PullRequest
       8

Jqgrid + CodeIgniter

4 голосов
/ 27 мая 2010

Я пытался заставить jqgrid работать с codeigniter, но я не смог этого сделать, я только хочу показать данные из таблицы в формате json ... но ничего не происходит ... но я не знаю, что я делаю неправильно я не могу увидеть таблицу с содержанием, которое я звоню.

мой контроллер

class Grid extends Controller
{

  public function f()
  {

       $this->load->model('dbgrid');
       $var['grid'] =  $this->dbgrid->getcontentfromtable();

       foreach($var['grid'] as $row) {
        $responce->rows[$i]['id']=$row->id;
        $responce->rows[$i]['cell']=array($row->id,$row->id_catalogo);

       }
     $json = json_encode($responce);
       $this->load->view('vgrid',$json);



  } 


  function load_view_grid()
  {

    $this->load->view('vgrid');


  }


}

моя модель

class Dbgrid extends Model{

function getcontentfromtable()
{


  $sql = 'SELECT * FROM anuncios';
  $query = $this->db->query($sql);
  $result = $query->result();


  return $result;   
}

мой взгляд (сценарий)

$(document).ready(function() { 
 jQuery("#list27").jqGrid({
        url:'http://localhost/sitio/index.php/grid/f',
        datatype: "json",
        mtype: "post",
        height: 255,
        width: 600,
        colNames:['ID','ID_CATALOGO'],
        colModel:[
            {name:'id',index:'id', width:65, sorttype:'int'},
            {name:'id_catalogo',index:'id_catalogo', sorttype:'int'}


        ],
        rowNum:50,
        rowTotal: 2000,
        rowList : [20,30,50],
        loadonce:true,
        rownumbers: true,
        rownumWidth: 40,
        gridview: true,
        pager: '#pager27',
        sortname: 'item_id',
        viewrecords: true,
        sortorder: "asc",
        caption: "Loading data from server at once" 
    });

}); 

надеюсь, кто-нибудь поможет мне

Ответы [ 4 ]

3 голосов
/ 05 января 2012

Я новый программист в коде воспламенителя. Я пытаюсь интегрировать jqgrid с воспламенителем кода, и через семь часов я пришел к успешной точке, где jqgrid и воспламенитель кода полностью интегрированы с опцией поиска.

Сначала напишите модель в каталоге вашего приложения / модели. Код ......

class JqgridSample extends CI_Model {

  function getAllData($start,$limit,$sidx,$sord,$where){
    $this->db->select('id,name,email,passport,phone,fax,address');
    $this->db->limit($limit);
    if($where != NULL)
        $this->db->where($where,NULL,FALSE);
    $this->db->order_by($sidx,$sord);
    $query = $this->db->get('info',$limit,$start);

    return $query->result();
  }
} 

Затем напишите контроллер в каталоге вашего приложения / контроллера. Код

class Demo extends CI_Controller {

function __construct() {
    parent::__construct();
    $this->load->model('JqgridSample');
}

function jqGrid(){
$this->load->view('showGrid');
}

function loadData(){
    $page = isset($_POST['page'])?$_POST['page']:1; 
    $limit = isset($_POST['rows'])?$_POST['rows']:10; 
    $sidx = isset($_POST['sidx'])?$_POST['sidx']:'name'; 
    $sord = isset($_POST['sord'])?$_POST['sord']:'';         
    $start = $limit*$page - $limit; 
    $start = ($start<0)?0:$start; 

    $where = ""; 
    $searchField = isset($_POST['searchField']) ? $_POST['searchField'] : false;
    $searchOper = isset($_POST['searchOper']) ? $_POST['searchOper']: false;
    $searchString = isset($_POST['searchString']) ? $_POST['searchString'] : false;

    if ($_POST['_search'] == 'true') {
        $ops = array(
        'eq'=>'=', 
        'ne'=>'<>',
        'lt'=>'<', 
        'le'=>'<=',
        'gt'=>'>', 
        'ge'=>'>=',
        'bw'=>'LIKE',
        'bn'=>'NOT LIKE',
        'in'=>'LIKE', 
        'ni'=>'NOT LIKE', 
        'ew'=>'LIKE', 
        'en'=>'NOT LIKE', 
        'cn'=>'LIKE', 
        'nc'=>'NOT LIKE' 
        );
        foreach ($ops as $key=>$value){
            if ($searchOper==$key) {
                $ops = $value;
            }
        }
        if($searchOper == 'eq' ) $searchString = $searchString;
        if($searchOper == 'bw' || $searchOper == 'bn') $searchString .= '%';
        if($searchOper == 'ew' || $searchOper == 'en' ) $searchString = '%'.$searchString;
        if($searchOper == 'cn' || $searchOper == 'nc' || $searchOper == 'in' || $searchOper == 'ni') $searchString = '%'.$searchString.'%';

        $where = "$searchField $ops '$searchString' "; 

    }

    if(!$sidx) 
        $sidx =1;
    $count = $this->db->count_all_results('info'); 
    if( $count > 0 ) {
        $total_pages = ceil($count/$limit);    
    } else {
        $total_pages = 0;
    }

    if ($page > $total_pages) 
        $page=$total_pages;
    $query = $this->JqgridSample->getAllData($start,$limit,$sidx,$sord,$where); 
    $responce->page = $page;
    $responce->total = $total_pages;
    $responce->records = $count;
    $i=0;
    foreach($query as $row) {
        $responce->rows[$i]['id']=$row->id;
        $responce->rows[$i]['cell']=array($row->name,$row->email,$row->passport,$row->phone,$row->fax,$row->address);
        $i++;
    }

    echo json_encode($responce);
}
}

И, наконец, вы пишете представление в каталоге вашего приложения / views ..

<head>

    <link rel="stylesheet" type="text/css" href="<?php echo base_url()?>application/views/css/custom-theme/jquery-ui-1.8.16.custom.css" />

    <link type="text/css" href="<?php echo base_url()?>application/views/css/ui.jqgrid.css" rel="stylesheet" />

    <link type="text/css" href="<?php echo base_url()?>application/views/css/plugins/searchFilter.css" rel="stylesheet" />

    <style>
        html, body {
            margin: 0;
            padding: 0;
            font-size: 75%;
        }
    </style>

    <script type="text/javascript" src="<?php echo base_url(); ?>application/views/js/jquery-1.5.2.min.js"></script>

    <script type="text/javascript" src="<?php echo base_url(); ?>application/views/js/i18n/grid.locale-en.js"></script>

    <script type="text/javascript" src="<?php echo base_url(); ?>application/views/js/jquery.jqGrid.min.js"></script>


    <title>Codeigniter With JQGrid</title>
</head>
<body>
    <center>
        <h1>Codeigniter With JQGrid</h1>
    <?php
        $ci =& get_instance();
        $base_url = base_url();
    ?>
    <table id="list"></table><!--Grid table-->
    <div id="pager"></div>  <!--pagination div-->
    </center>
</body>


<script type="text/javascript">
        $(document).ready(function (){
            jQuery("#list").jqGrid({
                url:'<?=$base_url.'index.php/demo/loadData'?>',      //another controller function for generating data
                mtype : "post",             //Ajax request type. It also could be GET
                datatype: "json",            //supported formats XML, JSON or Arrray
                colNames:['Name','Email','Passport','Phone','Fax','Address'],       //Grid column headings
                colModel:[
                    {name:'name',index:'name', width:100, align:"left"},
                    {name:'email',index:'email', width:150, align:"left"},
                    {name:'passport',index:'passport', width:100, align:"right"},
                    {name:'phone',index:'phone', width:100, align:"right"},
                    {name:'fax',index:'fax', width:100, align:"right"},
                    {name:'address',index:'address', width:100, align:"right"},
                ],
                rowNum:10,
                width: 750,
                //height: 300,
                rowList:[10,20,30],
                pager: '#pager',
                sortname: 'id',
                viewrecords: true,
                rownumbers: true,
                gridview: true,
                caption:"List Of Person"
            }).navGrid('#pager',{edit:false,add:false,del:false});
        });
    </script>

Для просмотра файла я создаю две папки в директории views js и css. и в js foder я помещаю jquery-1.5.2.min.js, grid.locale-en.js (views / js / i18n /), jquery.jqGrid.min.js, который вы найдете в пакете jqgrid.

Таким же образом требуется jquery-ui-1.8.16.custom.css, ui.jqgrid.css, который также доступен в пакете jqgrid.

для запуска полного процесса необходимо создать базу данных с именем jqgrid_sample и в базе данных создать таблицу с именем info, содержащую поля ...

ID

имя

Адрес электронной почты

паспорт

телефон

факс

адрес

вот и все. наслаждаться. до свидания.

3 голосов
/ 27 мая 2010

Данные, предоставленные сервером, которые вы публикуете в комментарии

{"rows":{"":{"id":"11","cell":["11","225101503"]}}} 

имеют неправильный формат. Вывод должен выглядеть как

{ 
  "total": "xxx", 
  "page": "yyy", 
  "records": "zzz",
  "rows" : [
    {"id" :"1", "cell" :["cell11", "cell12", "cell13"]},
    {"id" :"2", "cell":["cell21", "cell22", "cell23"]},
      ...
  ]
}

(см. http://www.trirand.com/jqgridwiki/doku.php?id=wiki:retrieving_data#json_data). Так что это должно быть как минимум

{"rows":[{"id":"11","cell":["11","225101503"]}]}

Как правило, если вы определите jsonReader, вы сможете прочитать практически любые данные. Получаемые вами данные могут быть прочитаны только с помощью jsonReader, определенного с помощью функций (см. http://www.trirand.com/jqgridwiki/doku.php?id=wiki:retrieving_data#jsonreader_as_function и jquery с ASP.NET MVC - вызов веб-службы с поддержкой ajax ). Самым простым способом для вас будет изменение кода вашего сервера для получения данных в стандартном формате (см. Выше), который можно прочитать по стандарту jsonReader.

И еще одно маленькое замечание. Использование sorttype не имеет никакого эффекта для datatype: "json". Параметр sorttype работает только с сортировкой локальных данных. В случае datatype: "json" сервер будет отвечать за правильную сортировку данных. jqGrid отправляет на сервер только имя столбца, который пользователь выбирает для сортировки данных.

0 голосов
/ 24 апреля 2014

Пожалуйста, обратите внимание: пример кода triand, который используется здесь много раз, имеет риск SQL-инъекции перед генерацией $where строки вы должны экранировать строку searchString, как;

заменить это:

$where = "$searchField $ops '$searchString' "; 

с этим:

$searchString = mysql_real_escape_string($searchString);
$where = "$searchField $ops '$searchString' "; 
0 голосов
/ 03 февраля 2013

Эти решения полностью покрывают загрузку данных JqGrid и CRUD. Это очень простая задача. Просто выполните следующие шаги и наслаждайтесь.

  1. Напишите модель, как показано ниже

    class gridAction_model extends CI_Model {
    
    public function __construct() {
        $this->load->database();
    }
    
    function getAllTeacherDesignation($start, $limit, $sidx, $sord, $where) {
    
        $this->db->select('DesignationId,DesignationName,Description,Status');
        $this->db->limit($limit);
        if ($where != NULL)
            $this->db->where($where, NULL, FALSE);
        $this->db->order_by($sidx, $sord);
        $query = $this->db->get('TeacherDesignation', $limit, $start);
    
        return $query->result();
    }
    
    function insert_teacherDesignation($data) {
        return $this->db->insert('TeacherDesignation', $data);
    }
    
    function update_teacherDesignation($id, $data) {
        $this->db->where('DesignationId', $id);
        return $this->db->update('TeacherDesignation', $data);
    }
    
    function delete_teacherDesignation($id) {
        $this->db->where('DesignationId', $id);
        $this->db->delete('TeacherDesignation');
    }
    

    }

  2. Теперь добавьте следующий метод в класс контроллера

        class grid_action extends CI_Controller {
    
    public function __construct() {
        parent::__construct();
        $this->load->helper("form");
        $this->load->model("gridAction_model");
    }
    
    public function loadTeacherDesignationData() {
    
        $page = isset($_POST['page']) ? $_POST['page'] : 1;
        $limit = isset($_POST['rows']) ? $_POST['rows'] : 10;
        $sidx = isset($_POST['sidx']) ? $_POST['sidx'] : 'DesignationName';
        $sord = isset($_POST['sord']) ? $_POST['sord'] : '';
        $start = $limit * $page - $limit;
        $start = ($start < 0) ? 0 : $start;
    
        $where = "";
        $searchField = isset($_POST['searchField']) ? $_POST['searchField'] : false;
        $searchOper = isset($_POST['searchOper']) ? $_POST['searchOper'] : false;
        $searchString = isset($_POST['searchString']) ? $_POST['searchString'] : false;
    
        if ($_POST['_search'] == 'true') {
            $ops = array(
                'eq' => '=',
                'ne' => '<>',
                'lt' => '<',
                'le' => '<=',
                'gt' => '>',
                'ge' => '>=',
                'bw' => 'LIKE',
                'bn' => 'NOT LIKE',
                'in' => 'LIKE',
                'ni' => 'NOT LIKE',
                'ew' => 'LIKE',
                'en' => 'NOT LIKE',
                'cn' => 'LIKE',
                'nc' => 'NOT LIKE'
            );
            foreach ($ops as $key => $value) {
                if ($searchOper == $key) {
                    $ops = $value;
                }
            }
            if ($searchOper == 'eq')
                $searchString = $searchString;
            if ($searchOper == 'bw' || $searchOper == 'bn')
                $searchString .= '%';
            if ($searchOper == 'ew' || $searchOper == 'en')
                $searchString = '%' . $searchString;
            if ($searchOper == 'cn' || $searchOper == 'nc' || $searchOper == 'in' || $searchOper == 'ni')
                $searchString = '%' . $searchString . '%';
    
            $where = "$searchField $ops '$searchString' ";
        }
    
        if (!$sidx)
            $sidx = 1;
        $count = $this->db->count_all_results('TeacherDesignation');
        if ($count > 0) {
            $total_pages = ceil($count / $limit);
        } else {
            $total_pages = 0;
        }
    
        if ($page > $total_pages)
            $page = $total_pages;
    
        $query = $this->gridAction_model->getAllTeacherDesignation($start, $limit, $sidx, $sord, $where);
    
        $responce = new stdClass;
    
        $responce->page = $page;
        $responce->total = $total_pages;
        $responce->records = $count;
        $i = 0;
    
        foreach ($query as $row) {
            $responce->rows[$i]['id'] = $row->DesignationId;
            $responce->rows[$i]['cell'] = array($row->DesignationId, $row->DesignationName, $row->Description, $row->Status);
            $i++;
        }
        echo json_encode($responce);
    }
    
    public function crudTeacherDesignation() {
    
        $oper = $this->input->post('oper');
        $id = $this->input->post('id');
        $DesignationId = $this->input->post('DesignationId');
        $DesignationName = $this->input->post('DesignationName');
        $Description = $this->input->post('Description');
        $Status = $this->input->post('Status');
    
        switch ($oper) {
            case 'add':
                $data = array('DesignationId' => $DesignationId, 'DesignationName' => $DesignationName, 'Description' => $Description, 'Status' => $Status);
                $this->gridAction_model->insert_teacherDesignation($data);
                break;
            case 'edit':
                $data = array('DesignationId' => $DesignationId, 'DesignationName' => $DesignationName, 'Description' => $Description, 'Status' => $Status);
                $this->gridAction_model->update_teacherDesignation($DesignationId, $data);
                break;
            case 'del':
                $this->gridAction_model->delete_teacherDesignation($DesignationId);
                break;
        }
    }  
    

    }

  3. Добавить скрипт при просмотре

     <table id="gridDesignation"> </table>
    
     <div id="pager"> </div>
    
    
    
    
    
            $(document).ready(function () {
    
        jQuery("#gridDesignation").jqGrid({
            url:'<?php echo base_url(); ?>grid_action/loadTeacherDesignationData',                
            mtype : "post",              //Ajax request type. It also could be GET
            datatype: "json",            //supported formats XML, JSON or Arrray
            colNames:['Designation ID','Designation Name','Description','Status'],       //Grid column headings
            colModel:[
                {name:'DesignationId',index:'DesignationId', width:100, align:"left", editable:true, editrules:{required:true}},
                {name:'DesignationName',index:'DesignationName', width:150, align:"left",editable:true,editrules:{required:true}},
                {name:'Description',index:'Description', width:100, align:"left", sortable:false, editable:true,editrules:{required:true}},
                {name:'Status',index:'Status', width:100, align:"right",editable:true,editrules:{required:true}, 
                    edittype:'select', editoptions:{value:"1:Active;0:InActive"}
                }
            ],
            rownumbers: true,
            rowNum:10,
            width: 750,
            height: "100%",
            rowList:[10,20,30],
            pager: jQuery('#pager'),
            sortname: 'DesignationName',
            autowidth: true,
            viewrecords: true,            
            gridview: true,  
            ondblClickRow: function(id){              
                $("#gridDesignation").editGridRow(id, {closeAfterEdit:true,mtype:'POST'});                
            },
            sortorder: "desc",       
            editurl: '<?php echo base_url() ?>grid_action/crudTeacherDesignation', //URL Process CRUD
            multiselect: false,
            caption:"List Of Teacher Designation"
        }).navGrid('#pager',
        {view:true,edit:true,add:true,del:true},
        {closeOnEscape:true},
        {closeOnEscape:true},
        {closeOnEscape:true},
        {closeOnEscape:true},
        {
            closeOnEscape:true,closeAfterSearch:false,multipleSearch:false, 
            multipleGroup:false, showQuery:false,
            drag:true,showOnLoad:false,sopt:['cn'],resize:false,
            caption:'Search Record', Find:'Search', 
            Reset:'Reset Search'
        }
    );        
    
    });
    
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...