“类数据表不存在”使用“yajra”laravel数据表时出错

时间:2015-10-14 10:11:17

标签: datatable laravel-5

我想通过 datatables jquery插件显示我的帖子表格行列表,其中laravel版本5.1来自yajra-laravel-datatables

为此,我在项目中执行此Quick Start Giude中描述的所有说明。

这是我的路线,仅用于获取dataTable所需的所有数据:

Route::get('postsData', 'postController@testData');

这是完整的postController php文件:

namespace App\Http\Controllers;

use App\Http\Requests;
use App\Post;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Input;
use Illuminate\Support\Facades\Redirect;
use Illuminate\Support\Facades\View;
use yajra\Datatables\Datatables;

class postController extends Controller
{

    public function index ()
    {
        $allPosts = Post::all();
        return \View::make('admin.pages.posts')->with('posts', $allPosts);
    }


    public function create ()
    {
        return \View::make('admin.pages.post_create');
    }


    public function store (Request $request)
    {
        $data = Input::all();

        $rules = array (
            'post_title' => 'required',
            'post_desc'  => 'required'
        );

        $validator = \Validator::make($data, $rules);

        if ($validator->fails()) {
            return \Redirect::to('/admin/posts/create')
                ->withErrors($validator)
                ->withInput();
        } else {

            $post             = new Post();
            $post->post_title = $data['post_title'];
            $post->post_desc  = $data['post_desc'];
            $post->save();

            return \Redirect::to('/admin/posts');
        }
    }


    public function show ($id)
    {
        $post = Post::find($id);

        return \View::make('admin.pages.show_post')->with('post', $post);
    }


    public function edit ($id)
    {
        $post = Post::find($id);
        return \View::make('admin.pages.edit_post')->with('post', $post);
    }


    public function update (Request $request, $id)
    {
        $data = Input::all();

        $rules = array (
            'post_title' => 'required',
            'post_desc'  => 'required'
        );

        $validator = \Validator::make($data, $rules);

        if ($validator->fails()) {
            return \Redirect::to('post/create')
                ->withErrors($validator)
                ->withInput();
        } else {

            $post             = Post::find($id);
            $post->post_title = $data['post_title'];
            $post->post_desc  = $data['post_desc'];
            $post->save();

            return \Redirect::to('admin/posts');
        }
    }


    public function destroy ($id)
    {
        $post = Post::find($id);
        $post->delete();

        return Redirect::to('admin/posts');
    }


    public function postsAll(){
        return View::make('admin.pages.postsAll');
    }

    public function testData(){
        return Datatables::of(Post::select('*'))->make(true);
    }
}

我还将服务提供商和外观添加到 config / app.php

return [
    'debug'           => env('APP_DEBUG', false),
    'url'             => 'http://localhost',
    'timezone'        => 'UTC',
    'locale'          => 'en',
    'fallback_locale' => 'en',
    'key'             => env('APP_KEY', 'SomeRandomString'),
    'cipher'          => 'AES-256-CBC',
    'log'             => 'single',


    'providers'       => [

        /*
         * Laravel Framework Service Providers...
         */
        Illuminate\Foundation\Providers\ArtisanServiceProvider::class,
        Illuminate\Auth\AuthServiceProvider::class,
        Illuminate\Broadcasting\BroadcastServiceProvider::class,
        Illuminate\Bus\BusServiceProvider::class,
        Illuminate\Cache\CacheServiceProvider::class,
        Illuminate\Foundation\Providers\ConsoleSupportServiceProvider::class,
        Illuminate\Routing\ControllerServiceProvider::class,
        Illuminate\Cookie\CookieServiceProvider::class,
        Illuminate\Database\DatabaseServiceProvider::class,
        Illuminate\Encryption\EncryptionServiceProvider::class,
        Illuminate\Filesystem\FilesystemServiceProvider::class,
        Illuminate\Foundation\Providers\FoundationServiceProvider::class,
        Illuminate\Hashing\HashServiceProvider::class,
        Illuminate\Mail\MailServiceProvider::class,
        Illuminate\Pagination\PaginationServiceProvider::class,
        Illuminate\Pipeline\PipelineServiceProvider::class,
        Illuminate\Queue\QueueServiceProvider::class,
        Illuminate\Redis\RedisServiceProvider::class,
        Illuminate\Auth\Passwords\PasswordResetServiceProvider::class,
        Illuminate\Session\SessionServiceProvider::class,
        Illuminate\Translation\TranslationServiceProvider::class,
        Illuminate\Validation\ValidationServiceProvider::class,
        Illuminate\View\ViewServiceProvider::class,
        Barryvdh\LaravelIdeHelper\IdeHelperServiceProvider::class,
        yajra\Datatables\DatatablesServiceProvider::class,
        /*
         * Application Service Providers...
         */
        App\Providers\AppServiceProvider::class,
        App\Providers\AuthServiceProvider::class,
        App\Providers\EventServiceProvider::class,
        App\Providers\RouteServiceProvider::class,

    ],



    'aliases'         => [

        'App'        => Illuminate\Support\Facades\App::class,
        'Artisan'    => Illuminate\Support\Facades\Artisan::class,
        'Auth'       => Illuminate\Support\Facades\Auth::class,
        'Blade'      => Illuminate\Support\Facades\Blade::class,
        'Bus'        => Illuminate\Support\Facades\Bus::class,
        'Cache'      => Illuminate\Support\Facades\Cache::class,
        'Config'     => Illuminate\Support\Facades\Config::class,
        'Cookie'     => Illuminate\Support\Facades\Cookie::class,
        'Crypt'      => Illuminate\Support\Facades\Crypt::class,
        'DB'         => Illuminate\Support\Facades\DB::class,
        'Eloquent'   => Illuminate\Database\Eloquent\Model::class,
        'Event'      => Illuminate\Support\Facades\Event::class,
        'File'       => Illuminate\Support\Facades\File::class,
        'Gate'       => Illuminate\Support\Facades\Gate::class,
        'Hash'       => Illuminate\Support\Facades\Hash::class,
        'Input'      => Illuminate\Support\Facades\Input::class,
        'Inspiring'  => Illuminate\Foundation\Inspiring::class,
        'Lang'       => Illuminate\Support\Facades\Lang::class,
        'Log'        => Illuminate\Support\Facades\Log::class,
        'Mail'       => Illuminate\Support\Facades\Mail::class,
        'Password'   => Illuminate\Support\Facades\Password::class,
        'Queue'      => Illuminate\Support\Facades\Queue::class,
        'Redirect'   => Illuminate\Support\Facades\Redirect::class,
        'Redis'      => Illuminate\Support\Facades\Redis::class,
        'Request'    => Illuminate\Support\Facades\Request::class,
        'Response'   => Illuminate\Support\Facades\Response::class,
        'Route'      => Illuminate\Support\Facades\Route::class,
        'Schema'     => Illuminate\Support\Facades\Schema::class,
        'Session'    => Illuminate\Support\Facades\Session::class,
        'Storage'    => Illuminate\Support\Facades\Storage::class,
        'URL'        => Illuminate\Support\Facades\URL::class,
        'Validator'  => Illuminate\Support\Facades\Validator::class,
        'View'       => Illuminate\Support\Facades\View::class,
        'Datatables' => yajra\Datatables\Datatables::class,

    ],

];

这是供应商编辑器文件夹中 yajra 的结构:

enter image description here

但是当我在浏览器中打开 postsData 路径时显示错误:

ReflectionException in Container.php line 737:
Class datatables does not exist

有什么问题?

5 个答案:

答案 0 :(得分:6)

我在谷歌搜索后找到了解决方案并尝试了不同的方法:

1.首先将您的项目重命名为新名称 2.使用composer update
3.run php artisan config:cache
4.并运行php artisan cache:clear

再次尝试使用您的代码。

答案 1 :(得分:2)

尝试更改控制器

卸下:

use yajra\Datatables\Datatables;

添加

use Datatables;

config/app.php

您必须拥有提供者:

 yajra\Datatables\DatatablesServiceProvider::class,

并且必须有别名:

'Datatables' => yajra\Datatables\Datatables::class,

答案 2 :(得分:2)

我设法修复相同的错误。

在config / app.php中

Yajra\DataTables\DatatablesServiceProvider::class,
Datatables' => Yajra\DataTables\Facades\Datatables::class,

请确保您将“T'在' \ DataTables \'

参考。 https://github.com/yajra/laravel-datatables/issues/986

答案 3 :(得分:0)

如果您没有conf / datatables.php,也会发生同样的错误。尝试安装最新或更高版本7.x

composer require yajra/laravel-datatables-oracle

在config / app.php中添加这些行

Yajra\Datatables\DatatablesServiceProvider::class,

Datatables' => Yajra\Datatables\Facades\Datatables::class,

php artisan config:cache

如果您没有文件config / datables.conf。尝试将这些文件粘贴到那里。 https://gist.github.com/hsali/1cab0d6c81020bf7bce043b65f94373a

答案 4 :(得分:0)

试试这个:

use Yajra\Datatables\Facades\Datatables;