我到处都是stackoverflow和google,似乎无法解决找不到的trait函数。我已经尝试过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从特征中获取功能。当我尝试获取要在查询中使用的函数时,它说:调用未定义的函数App \ Http \ Controllers \ selectPrepare()
我缺少什么吗?我是laravel traits功能的新手,但我认为我遵循所有示例和命名约定。谁能看到我在做什么错。
答案 0 :(得分:3)
访问特征方法时,您需要使用$this
,就像使用任何其他方法一样:
$users = User::when($request->has('select'), function ($query) use ($request) {
$this->selectPrepare($query, $request->input('select'));