Laravel - 使用bundle从db中检索数据

时间:2013-05-21 06:33:17

标签: php mysql laravel laravel-3 charisma

首先,我是Laravel和MVC环境的新手。对于这个项目,我使用MySQL作为数据库,使用Charisma作为捆绑。我在尝试从db检索数据时遇到了困难。我想知道是否有人会引导我解决所有这些问题。

  1. 如果我使用捆绑包,我在哪里放置所有型号,控制器和路线?在/application文件夹中,还是在软件包的文件夹中?
  2. 何时使用/application文件夹,何时使用Charisma文件夹? (显然,我只是将它用于前端用户界面)
  3. 我的数据库表(名为user_links)中有一条记录,用于测试Charisma View中的数据检索。我该怎么做?
  4. 我正在使用此CRUD Tutorial in Laravel作为指南,但在使用捆绑包时会有点混乱。

    好的,让我试试吧。我要在这里做一个检索。我希望有人可以指出错误并指导我修复。:

    表格名称user_links

    id: int
    user_id: varchar
    link_title: text
    link_url: text
    

    模型 /application/models/user_links.php(因为Charisma没有/models文件夹,我将使用默认文件夹):

    class User_Link extends Eloquent{
    }
    

    控制器 bundles/charisma/controllers/user_link.php(使用Charisma控制器文件夹)

    class Charisma_User_Link_Controller extends Base_Controller{
    
      public $restful = true;
    
      public function get_index(){
     $user_links =  User_Link(); 
    return View::make('user_links.index')
    ->with('link_title', 'Link Title')
    ->with('link_url', 'URL');
      }
    }
    

    查看 /bundles/charisma/views/pages/index.blade.php

    <div >
    @foreach($user_link->results as $user_links)
        {{ $user_links::link_title }}
        {{ $user_links::link_url }}
    @endforeach
    </div>
    

    路线 /bundles/charisma/routes.php

    Route::controller('charisma::user_link');
    

    这就是全部。当然会有一些错误,但如果你需要更多的东西请告诉我。提前谢谢。

1 个答案:

答案 0 :(得分:2)

您应该使用前端UI的应用程序文件夹,因为charismaadmin bundle并且它是专为应用程序设计的,那些有后端支持来设置和维护各种系统配置,就像自定义cms

Laravel-3中,application文件夹是将控制器,模型和视图保存在相应文件夹中的默认位置,并使用application/routes.php来路由控制器。

但是,如果要将另一个包用作charisma,则应将捆绑包保留在捆绑包目录的根目录中,并将捆绑包名称添加到bundles.php文件中的数组中。例如,我在我的一个项目中使用charisma作为我的管理面板的捆绑包,文件夹的名称是admin,我放置了charisma的文件(我将charisma重命名为admin)

return array(
    'admin' => array('handles' => 'hit_admin'), <-- added for admin bundle
    // more bundles..........
);

我的目录结构为domain_root/bundles/admin,管理员为charisma(已重命名),您还必须将捆绑包routes.php用于该捆绑包的控制器。例如,在domain_root/bundles/admin中我有一个routes.php文件,我已经在该文件中注册了管理包的所有路由,而管理包中有自己的控制器,视图,模型和公共文件夹。所以,基本上,我不得不使用这些文件夹。所有管理员控制器都在domain_root/bundles/admin/controllers文件夹中,对于模型和视图也是如此。每个捆绑包都有自己的公共文件夹来保存它自己的资产。

admin/routes.php中,路线就是这样的

Route::any('(:bundle)', array('as' => 'admin_home', 'uses' => 'admin::home@index'));

管理包中的每个控制器都可以扩展它自己的基本控制器,例如,我用过,

class Admin_Home_Controller extends Admin_Base_Controller {
    // ...
}

base.php文件夹中有一个admin/controllers文件,它是管理员基础控制器,它是这样的

class Admin_Base_Controller extends Controller {

    public function __construct()
    {
        parent::__construct();

        // Add assets for admin
        Asset::add('jQuery', 'js/jquery-1.7.2.min.js');
    }

    public function __call($method, $parameters)
    {
        return Response::error('404');
    }

}

有关详细信息,您可以查看this tutorial并阅读documentation