Pregunta

He tomado algunas respuestas tanto de SO como de los foros de Laravel para reconstruir los resultados.Sin embargo, estoy teniendo un Undefined variable error y no estoy seguro de por qué.

Controlador

public function getJobs()

        {
            $query = DB::table('jobs');

            if (isset($jcategory))
            $query->where('category', '=', $jcategory);

            $result = $query->get();
           return View::make('jobsearch.search', $result);
        }

Ver (ha sido abreviado por espacio)

<form action="{{ action('JobsearchController@getJobs') }}" method="post">
  <div class="row">
    <div class="large-8 columns">
      <input type="text" name="realm" placeholder="Keywords/Skills" />
    </div>
    <div class="large-4 columns">
        <select name="jcategory">
        <option value="">Select Category</option>
        <option value="jc1">Accounting</option>

...

 </select>
    </div>
    <div class="large-4 columns">
       <input type="submit" value="Search" style="width:100%; padding-top: .5rem;
padding-bottom: .5rem;" class="button border-btn" />
      </div>


</div>
</form>

@foreach ($result as $job)
    <p>{{ $job->id }}</p>
@endforeach

Una vez que haga funcionar esta pequeña prueba, agregaré el resto del isset en el $query.Lo que intento lograr es que la vista cargue todos los trabajos en la base de datos y si el usuario cambia la categoría (por ejemplo) y envía la vista, recargará la página con los cambios reflejados en la consulta.

Actualmente recibo un Undefined variable: result error en la vista.he probado el foreach de diferentes maneras, pero tengo la sensación de que el controlador no pasa nada.

¿Fue útil?

Solución

Pasaste el $result variable de forma incorrecta.Prueba esto:

return View::make('jobsearch.search')->with('result', $result);
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top