Laravel - "Метод подсветки \\ База данных \\ Запрос \\ Builder :: рецептов не существует" - PullRequest
0 голосов
/ 29 июня 2018

Я смотрел на несколько подобных проблем в SO, но не могу понять, почему называются рецепты?

Я создаю веб-сайт рецептов, и пользователь может создавать теги, создавать рецепты, создавать ингредиенты, которые назначены для рецепта, и сможет создавать шаги, в которых используются ингредиенты.

Ниже приведены мои модели:

Ingredient.php

class Ingredient extends Model
{
  protected $touches = ['recipes'];

  public function recipes(){
    return $this->belongsToMany('App\Recipe', 'recipe_ingredients', 'ingredient_id', 'recipe_id');
  }

  public function step(){
    return $this->belongsToMany('App\Step', 'step_ingredients');
  }

}

Recipe.php

class Recipe extends Model
{
  public function ingredients(){
    return $this->belongsToMany ('App\Ingredient', 'recipe_ingredients', 'recipe_id', 'ingredient_id');
  }

  public function tags(){
    return $this->belongsToMany('App\Tag', 'recipe_tag');
  }

  public function user(){
    return $this->belongsTo('App\User');
  }

  public function steps(){
    return $this->hasMany('App\Step');
  }
}

Step.php

class Step extends Model
{

  protected $touches = ['recipes'];

  public function recipe(){
    return $this->belongsTo('App\Recipe');
  }

  public function ingredient(){
    return $this->belongsToMany('App\Ingredient', 'step_ingredient');
  }
}

Ниже приведен мой StepsController , который я сохраняю из моего файла steps / create.blade.php через Ajax, отправленный с помощью jQuery.

use Illuminate\Http\Request;
//use Session;
use App\Recipe;
use App\Tag;
use App\Step;
use App\Ingredient;

class StepsController extends Controller
{
    public function __construct()
    {
        $this->middleware('auth');
    }

    public function create($recipe_id)
    {
      $recipe = Recipe::find($recipe_id);
      return view('steps.create')->withRecipe($recipe);
    }

    public function store(Request $request)
    {

      $step = new Step;
      $step->recipe_id = 2;
      $step->step_no = 2;
      $step->is_prep = 1;
      $step->duration = '00:14:01';
      $step->method = 'test';
      $step->save();

      $data = [
        'success' => true,
        'message'=> 'Your AJAX processed correctly',
        'ing' => json_decode($request->ingredients),
        'desc' => $request->description
      ] ;

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

Я использую статические значения для new Step, чтобы убедиться, что он правильно пишет в БД, и это так.

Если я закомментирую запись шага в базу данных и просто оставлю массив $data и return response..., тогда он будет работать нормально, и я получу ответ об успешном возвращении в представление.

Когда я включаю его, я получаю сообщение об ошибке в консоли:

[Error] Failed to load resource: the server responded with a status of 500 (Internal Server Error) (steps, line 0)

"message": "Method Illuminate\\Database\\Query\\Builder::recipes does not exist.",

Но я не уверен где вызывается метод рецептов ?! Я думаю, это как-то связано с моими отношениями в модели?

Любое понимание будет чрезвычайно ценно.

Не уверен, требуется ли это, но ниже приводится часть моего скрипта, которую я использую, поэтому отправляйте данные с помощью Ajax.

$("#addStepNew").click(function() {
    var step_ingredients = JSON.stringify(stepIngredients)
    var step_description = $('#stepDescription').val();
    // var prep_step = $('input[name=prepStep]:checked').val();

  $.ajax({
    headers: {
      'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
      },
    type: "post",
    data: {ingredients: step_ingredients, description: step_description},
    dataType:'json',
    url: "{{ route('steps.store', ['id' => $recipe->id]) }}",

    success: function (data) {
      $("#ajaxOutput").html('<code>Description output: '+data.desc+'</code>');
      $.each(data.ing, function (key, value) {
        $("#ajaxOutput").append('<br><code>'+value.ingredient_name+'</code>');
      });          
    },
    error: function (xhr, ajaxOptions, thrownError) {
      console.warn(xhr.responseText);
      alert(xhr.status);
      alert(thrownError);
    }
  });
});

1 Ответ

0 голосов
/ 29 июня 2018

Похоже, это protected $touches = ['recipes']; от Step модели.

Я думаю, что он пытается обновить рецепт, с которым он связан, но это не определяется с помощью recipe_id.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...