Laravel 特征函数未找到

问题描述 投票:0回答:1

我查遍了 stackoverflow 和 google,但似乎无法解决我的特征函数未找到的问题。我尝试过composer dump-autoload,我的composer.json已连接应用程序目录,甚至检查了我的命名空间和特征名称。这是我的用户控制器。

<?php

namespace App\Http\Controllers;

use App\User;
use App\Traits\ControllerTrait;
use App\Http\Requests\UpdateUser;
use Illuminate\Http\Request;
use App\Http\Requests\IndexUser;

class UserController extends Controller
{
    use ControllerTrait;

    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('auth');
    }

    /**
     * Show multiple users.
     *
     * @return \Illuminate\Http\Response
     */
    public function index(IndexUser $request)
    {
        $per_page = 50;
        $order_by = 'id';
        $sort_by = 'ASC';

        if($request->has('per_page')) {
            $per_page = $request->input('per_page');
        }

        if($request->has('order_by')) {
            $order_by = $request->input('order_by');
        }

        if($request->has('sort_by')) {
            $sort_by = $request->input('sort_by');
        }

        $users = User::when($request->has('select'), function ($query) use ($request) {
            selectPrepare($query, $request->input('select'));
        })->when($request->has('include'), function ($query) use ($request) {
            if(!empty($request->input('include'))) {
                $includedTables = explode(',', $request->input('include'));
                $tables = array_map('trim', $includedTables);

                return $query->with($tables);
            }

            return $query;
        })->orderBy("{$order_by}", "{$sort_by}")
        ->paginate($per_page);

        return response()->json($users);
        }
    }
}

这就是我的特点

    <?php

    namespace App\Traits;

    trait ControllerTrait
    {
        /**
         *  Function: scopeSelectPrepare

    public function selectPrepare($query, $select) {
        if(!empty($select)) {
            $selectedColumns = explode(',', $select);
            $columns = array_map('trim', $selectedColumns);

            return $query->select($columns);
        }

        return $query;
    }
}

正如您所看到的,我的 Trait 名称空间是 App\Traits 并在我的控制器中调用 use App\Traits\ControllerTrait 然后可以使用 ControllerTrait 从 Trait 获取函数。当我尝试获取要在查询中使用的函数时,它显示:调用未定义的函数 App\Http\Controllers\selectPrepare()

我有什么遗漏的吗?我对 Laravel 的特征功能很陌生,但我认为我遵循了所有示例和命名约定。谁能看到我做错了什么。

php laravel eloquent traits laravel-query-builder
1个回答
3
投票

访问特征方法时需要使用

$this
,就像访问任何其他方法一样:

$users = User::when($request->has('select'), function ($query) use ($request) {
    $this->selectPrepare($query, $request->input('select'));
© www.soinside.com 2019 - 2024. All rights reserved.