ErrorException в строке IncomesController.php 45: неопределенная переменная: type_id

Это ошибка, которую он возвращает мне, когда я пытаюсь отправить новый доход. Я новичок в Laravel 5.3, поэтому у меня много ошибок, особенно в отношении FK и отношений; будь свободен указать на это. И, чтобы указать, у меня уже есть 3 записи типов, и я могу видеть и выбирать их в представлении.

<?php

use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateTypesTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('types', function (Blueprint $table) {
            $table->increments('id');
            $table->string('type_name');
            $table->timestamps();
        });

        Schema::table('incomes', function (Blueprint $table) {
            $table->foreign('type_id')->references('id')->on('types')->onDelete('cascade');
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::table('incomes', function (Blueprint $table) {
            $table->dropColumn('type_id');
        });

        Schema::dropIfExists('types');
    }
}

<?php

use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateIncomesTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('incomes', function (Blueprint $table) {
            $table->increments('id');
            $table->decimal('quantity', 15,2);
            $table->date('date');
            $table->integer('type_id')->unsigned();
            $table->timestamps();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('incomes');
    }
}

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Type;
use DB;
use App\Income;

class IncomesController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {
        $income = Income::orderBy('id', 'ASC')->paginate(10);

        return view('admin.incomes.index')->with("incomes", $income);
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        $types = DB::table('types')->pluck('type_name', 'id');
        var_dump($types);
        return view('admin.incomes.create')->with('types', $types);
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function store(Request $request)
    {
        $income = new Income($request->all());
        $income->types()->save($type_id);
        $income->save();
        return redirect()->route('admin.incomes.index');
    }

    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function show($id)
    {
        $income = Income::find($id);
    }

    /**
     * Show the form for editing the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function edit($id)
    {
        $income = Income::find($id);
         return view('admin.incomes.edit')->with('incomes', $income);
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, $id)
    {
        $income = Income::find($id);
        $income->quantity = $request->quantity;
        $income->save();

        Flash::info("El ingreso ha sido editado con exito!");

        return redirect()->route('admin.incomes.index');
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function destroy($id)
    {
        $income = Income::find($id);
        $income->delete();

        Flash::error('El ingreso de ' . $income->quantity . ' ha sido eliminado con exito!');
        return redirect()->route('admin.incomes.index');
    }
}

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Type;

class TypesController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {
        $type = Type::orderBy('id', 'ASC')->paginate(5);

        return view('admin.types.index')->with("types", $type);
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        return view('admin.types.create');
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function store(Request $request)
    {
        //$type = new Type($request->all());
        $type = new Type;
        $type->type_name = $request->get('type_name');
        $type->save();
        return redirect()->route('admin.types.index');
    }

    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function show($id)
    {
        $type = Type::find($id);
    }

    /**
     * Show the form for editing the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function edit($id)
    {
        $type = Type::find($id);
         return view('admin.types.edit')->with('types', $type);
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, $id)
    {
        $type = Type::find($id);
        $type->type_name = $request->type_name;
        $type->save();

        Flash::info("El tipo " . $type->type_name . " ha sido editado con exito!");

        return redirect()->route('admin.types.index');
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function destroy($id)
    {
        $type = Type::find($id);
        $type->delete();

        Flash::error('El tipo ' . $type->type_name . ' ha sido eliminado con exito!');
        return redirect()->route('admin.types.index');
    }
}

И это мое мнение о доходах:

@extends('admin.template.main')

@section('title', 'Nuevo ingreso')

@section('content')
<?php 
use App\Type;
use App\Income;

 ?>
    {!! Form::open(['route' => 'admin.incomes.store', 'method' => 'POST']) !!}
        <div class="form-group">
            {!! Form::label('quantity', 'Cantidad') !!}
            {!! Form::text('quantity', null, ['class' => 'form-control', 'placeholder' => 'Cantidad de ingreso', 'required']) !!}
        </div>
        <div class="form-group">
            {!! Form::label('type_id', 'Tipo') !!}
            {!! Form::select('type_id', $types, null) !!}
        </div>
        <div class="form-group">
            {!! Form::label('date', 'Fecha') !!}
            {!! Form::date('date', null, ['class' => 'form-control', 'placeholder' => 'Fecha de ingreso', 'required']) !!}
        </div>
        <div class="form-group">
            {!! Form::submit('Registrar', ['class' => 'btn btn-primary']) !!}
        </div>
        dd($request->all());
    {!! Form::close() !!}

@endsection

1 ответ

/**
 * Store a newly created resource in storage.
 *
 * @param  \Illuminate\Http\Request  $request
 * @return \Illuminate\Http\Response
 */
public function store(Request $request)
{
    $income = new Income($request->all());
    /* There you have a variable $type_id
     * but you do not assign it anywhere.
     */
    $income->types()->save($type_id /* <- there */);
    $income->save();
    return redirect()->route('admin.incomes.index');
}

Вы пытаетесь использовать переменную $type_id который не существует Я предполагаю, что вы хотите иметь значение из формы в этой переменной, тогда вам нужно получить значение из Request объект:

$type_id = $request->input('type_id', 'default_value');
$income->types()->save($type_id);
Другие вопросы по тегам