受到其他社区 wiki 的启发,我有兴趣了解鲜为人知的 Kohana 提示、技巧和功能。
- 请每个答案只包含一个提示。
- 如有必要,添加 Kohana 版本。
这是一个社区维基。
受到其他社区 wiki 的启发,我有兴趣了解鲜为人知的 Kohana 提示、技巧和功能。
这是一个社区维基。
$options = ORM::factory('model')
->order_by('title','ASC')
->find_all()
->as_array('id','title');
$select = Form::select('name', $options);
需要注意的是,这不仅限于 ORM,还可以用于所有数据库结果(它们都支持 as_array)。有关详细信息,请参阅数据库结果信息。
如果要添加默认选项:
$options = Arr::merge(array('Please select a value.'), $options);
将这些行粘贴到您的.htaccess
:
SetEnvIf SERVER_ADDR "^(127\.0\.0\.1|::1)$" KOHANA_ENV=development
SetEnvIf SERVER_ADDR "^((?!127\.0\.0\.1|::1).)*$" KOHANA_ENV=production
现在,如果您在本地主机上,则处于开发模式,否则您处于生产模式
编辑:增加了对 IPv6 的支持
this->request->route->uri()
和this->request->uri()
(Kohana 3)之间的区别
// Current URI = welcome/test/5
// Using default route ":controller/:action/:id"
// This returns "welcome/test/5"
echo $this->request->uri();
// This returns "welcome/test1/5"
echo $this->request->uri(array( 'action' => 'test1' ));
// This returns "welcome/index"
echo $this->request->route->uri();
// This returns "welcome/test1"
echo $this->request->route->uri(array( 'action' => 'test1' ));
如您所见, $this->request->route->uri() 使用当前路由默认值(id 为空),而 $this->request->uri() 应用当前 uri 段。
ORMsadd
函数接受第三个参数,您可以在其中指定要保存在 1pivot table1 上的其他数据。
例如,如果一个用户有很多角色并且一个角色有很多用户(通过名为 1roles_users1 的表),您可以通过将列键和数据值数组作为第三个参数传递给该add
方法,将信息保存到 1pivot table1。
不支持。另一种方法是pivot table
像使用任何其他表一样加载和添加数据。
$user->add('role', $role, array('date_role_added' => time()));
$role
在 哪里ORM::factory('role', array('name' => 'user'));
这些代码示例假定您从模板控制器扩展。
public function before()
{
parent::before();
if (Request::current()->is_ajax())
{
$this->auto_render = FALSE;
}
}
public function before()
{
parent::before();
if (Request::$is_ajax)
{
$this->auto_render = FALSE;
}
}
与其在 HTML 和 PHP 中硬编码锚位置,倒不如反向路由。这实质上意味着您定义路线位置,然后使用它们;如果您需要更改位置,它可以在一个地方完成,而不是数百个。
路由可以在任何地方定义,但最好将它们放入应用程序引导程序或模块引导程序 (init.php)。
它们设置如下:
Route::set('name', '<controller>(/<action>)', array('action' => 'login|logout');
<part>
匹配的内容。当一个部分被括号包围时,该部分是可选的。如果用户没有提供部件并且您想提供默认值,则使用 defaults 方法指定值。
->defaults(array('action' => 'login'));
以下代码现在用于具有可逆路线。URL 路径可以更新,您的所有 URL都应该像以前一样工作。
Route::url('name', array('controller' => 'user', 'action' => 'login'));
Set base_url
automatically:
Kohana::init(array(
// ...
'base_url' => dirname($_SERVER['SCRIPT_NAME']),
// ...
));
If your site is hosted at 1&1, you should use:
Kohana::init(array(
// ...
'base_url' => substr($_SERVER["SCRIPT_NAME"], 0, strpos($_SERVER["SCRIPT_NAME"], basename($_SERVER["SCRIPT_FILENAME"])));
// ...
));
(taken from Gallery3 config file )
这些被称为子请求。查看 Sam de Freyssinets 文章:使用 HMVC 扩展 Web 应用程序以获得更深入的解释。请注意版本之间的初始与实例差异。
if (Request::initial() !== Request::current())
{
print 'Internal called made with Request::factory';
}
if (Request::instance() !== Request::current())
{
print 'Internal called made with Request::factory';
}
该函数同时检查内部和 AJAX 请求。如果页面的某些部分最初使用 HMVC 技术加载,然后可以使用 AJAX 重新加载,这可能会很方便。将它与一些基本控制器一起放置,您可以从中扩展所有适当的控制器(我称之为“基本控制器”):
public function is_remote()
{
if ($this->request->is_initial())
{
if ($this->request->is_ajax())
{
return TRUE;
}
else
{
return FALSE;
}
}
else
{
return TRUE;
}
}
一种更短(等效)的写法:
public function is_remote()
{
return ( ! $this->request->is_initial() || $this->request->is_ajax());
}
希望这可以帮助。
如果您需要显示错误页面,Kohana 已经为它内置了异常。抛出异常后,您可以创建自定义异常处理程序并显示 HTML 错误页面。您需要一个开关来显示开发中的真正错误。
throw new HTTP_Exception_404('The article :article was not found',
array(':article' => $article->name));
第二个参数为您提供了一种替换错误消息中的字符串的方法。
没有捆绑 HTTP 异常。您应该创建自己的异常并处理它们。Kohana 有一个教程:Kohana - 自定义错误页面
TRUNCATE mytable
要像使用准备好的语句一样执行 SQL 查询,请将null
其作为第一个参数传递给DB::query()
方法。当查询不适合任何 CRUD 操作时很有用。