我正在尝试将phpgrid与我的codeigniter程序集成。
我需要对如何使用库函数做一些澄清。
我已将phpgrid文件添加到应用程序/库路径,并使用$this->load->library('phpGrid');
以下是phpgrid conf.php文件中的代码。
<?php
// mysql example
define('DB_HOSTNAME','localhost'); // database host name
define('DB_USERNAME', 'admin'); // database user name
define('DB_PASSWORD', 'pop3'); // database password
define('DB_NAME', xtra); // database name
define('DB_TYPE', 'mysql'); // database type
define('DB_CHARSET','utf8'); // ex: utf8(for mysql),AL32UTF8 (for oracle), leave blank to use the default charset
define('SERVER_ROOT', '/grid');
/******** DO NOT MODIFY ***********/
require_once('phpGrid.php');
/**********************************/
?>
有人可以帮助我如何将define和require_once文件引用到我的库路径?
或者还有其他方法可以将phpgrid文件包含到我的CI项目中吗?
答案 0 :(得分:7)
我刚刚查看了PHPgrid源文件,看起来它们已加密,因此您可以在多大程度上与Codeignite MVC框架完全“集成”。
要使用这样的外部库,我通常会这样做:
存储一个单独的config.php文件(看起来像PHPgrid文件),它定义了根目录中的db连接常量。
然后在Codeigniter config / database.php文件中要求它,并使用常量来设置Codeigniter设置。所以你的Codeigniter database.php看起来像是:
require_once('config.php');
$db['default']['hostname'] = DB_HOSTNAME;
$db['default']['username'] = DB_USERNAME;
$db['default']['password'] = DB_PASSWORD;
$db['default']['database'] = DB_NAME;
您不希望在整个地方存储数据库连接详细信息。
然后在你的phpgrid / conf.php文件的顶部包含config.php,并使用常量以相同的方式填充细节,显然也填写其他的phpgrid常量。
将所有PHPgrid文件放在应用程序/库的子目录中。现在在您的应用程序/库文件中创建一个名为ci_phpgrid.php的新文件,并在其中创建一个新类,如下所示:
<?php
require_once('phpgrid/conf.php');
class CI_phpgrid {
public function example_method($val = '')
{
$dg = new C_DataGrid("SELECT * FROM Orders", $val, "Orders");
return $dg;
}
}
您现在可以使用它与php网格进行通信,保留原始文件。
在你的控制器中,你可以做类似的事情:
$this->load->library('ci_phpgrid');
$data['phpgrid'] = $this->ci_phpgrid->example_method(3)
$this->load->view('home_page',$data);
然后在视图中,您可以使用以下方式显示表格:
$phpgrid->display()
正如我所提到的,我没有使用PHPgrid,你需要包含所有相关的JS用于排序等,但这通常是你想要在CI中接近外部库的方式。