我查遍了 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 的特征功能很陌生,但我认为我遵循了所有示例和命名约定。谁能看到我做错了什么。
访问特征方法时需要使用
$this
,就像访问任何其他方法一样:
$users = User::when($request->has('select'), function ($query) use ($request) {
$this->selectPrepare($query, $request->input('select'));