如何在laravel中的选择选项值中显示所选标签?

时间:2018-06-20 09:43:31

标签: laravel many-to-many relationship

这是我的帖子创建视图

<div class="col-lg-12">
    <form action="{{ route('admin.post.store') }}" enctype="multipart/form-data" method="post">
        {{ csrf_field() }}
        <div class="form-group">
            <label for="title">Post Title</label>
            <input type="text" class="form-control" value="{{ old('title') }}" name="title" id="title"
                   placeholder="Enter Post Title">
            <span class="text-danger">{{ $errors->first('title') }}</span>
        </div>
        <div class="form-group">
            <label for="slug">Post Image</label>
            <input type="file" class="form-control" name="image" id="image"
                   placeholder="Select Post Image">
            <span class="text-danger">{{ $errors->first('image') }}</span>
        </div>
        <div class="form-group">
            <label for="tags">Select Tags</label>
            <select multiple class="form-control" name="tags[]" id="tags">
                @foreach($tags as $id => $name)
                    <option id="{{ $id }}">{{ $name }}</option>
                @endforeach
            </select>
        </div>
        <div class="form-group">
            <textarea class="body" name="body">{{ old('body') }}</textarea>
            <span class="text-danger">{{ $errors->first('body') }}</span>
        </div>
        <div class="form-group">
            <label for="category">Select Category</label>
            <select class="form-control" name="category" id="category">
                <option value="">Select</option>
                @foreach($cats as $cat)
                    <option value="{{ $cat->id }}">{{ $cat->name }}</option>
                @endforeach
            </select>
        </div>
        <button type="submit" class="btn btn-success btn-block">Publish</button>
    </form>
</div>

标签具有多对多关系。 在这里,我可以选择许多标签,但是在帖子编辑视图中,看不到我在帖子创建视图中选择的所选标签。 我想在选择选项值中显示所选标签并编辑主题。

更新后的方法:

public function edit(Post $post)
{
    $tags = Tag::all()->pluck('name', 'id');
    $cats = Category::all();
    return view('admin.post.edit', compact(['post', 'cats', 'tags']));
}

public function update(Post $post, Request $request)
{
    $this->validate($request, [
        'title' => 'required|min:3|max:255',
        'slug' => 'nullable|string',
        'image' => 'sometimes|mimes:jpeg,bmp,png,jpg,gif',
        'body' => 'required',
        'category' => 'nullable',
        'views' => 'nullable',
        'tags' => 'nullable',
    ]);

    $post->title = $request->title;
    $post->slug = $request->slug;
    $post->body = $request->body;
    $post->category_id = $request->category;

    if ($request->hasFile('image')) {
        $image = $request->file('image');
        $filename = time() . '.' . $image->getClientOriginalExtension();
        $location = public_path('images/' . $filename);
        Image::make($image)->resize(800, 400)->save($location);

        $oldfilename = $post->image;

        $post->image = $filename;

        Storage::delete($oldfilename);
    }

    $post->save();

    $post->tags()->sync($request->tags, false);

    Session::flash('update', 'Post Updated Successfully');

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

发布修改视图:

<div class="col-lg-12">
    <form action="{{ route('admin.post.update',$post->id) }}" enctype="multipart/form-data" method="post">
        {{ csrf_field() }}
        {{ method_field('patch') }}
        <div class="form-group">
            <label for="title">Post Title</label>
            <input type="text" class="form-control" value="{{ $post->title }}" name="title" id="title"
                   placeholder="Enter Post Title">
            <span class="text-danger">{{ $errors->first('title') }}</span>
        </div>
        <div class="form-group">
            <label for="slug">Post Image</label>
            <input type="file" class="form-control" name="image" id="image"
                   placeholder="Select Post Image">
            <span class="text-danger">{{ $errors->first('image') }}</span>
        </div>
        <div class="form-group">
            <label for="tags">Select Tags</label>
            <select class="js-example-basic-single form-control" name="tags[]" id="tags" multiple="multiple">

            </select>
        </div>
        <div class="form-group">
            <textarea class="body" name="body">{{ $post->body }}</textarea>
            <span class="text-danger">{{ $errors->first('body') }}</span>
        </div>
        <div class="form-group">
            <label for="category">Select Category</label>
            <select class="form-control" name="category" id="category">
                <option value="">Select</option>
                @foreach($cats as $cat)
                    <option <?php if ($cat->id == $post->category_id) {
                        echo 'selected';
                    } ?> value="{{ $cat->id }}">{{ $cat->name }}</option>
                @endforeach
            </select>
        </div>
        <button type="submit" class="btn btn-primary btn-block">Edit</button>
    </form>
</div>

此处:

<div class="form-group">
    <label for="tags">Select Tags</label>
    <select multiple class="form-control" name="tags[]" id="tags">
        @foreach($tags as $id => $name)
            <option id="{{ $id }}">{{ in_array($id,$post->category()->pluck('id')->toArray()) ? 'selected' : '' }}</option>
        @endforeach
    </select>
</div>

如何传递数据库中选定的帖子标签并在此处显示主题并进行编辑。

我正在使用select2插件

在select2中,我应该在jQuery中传递数据:

$('.js-example-basic-single').select2().val({{ json_decode($post->tags()->getRelatedIds()) }}).trigger('change');

但是它不起作用:(

我得到这个错误

  

方法Illuminate \ Database \ Query \ Builder :: getRelatedIds不存在。 (查看:C:\ Users \ M0RT3Z4 \ Desktop \ MyBlog \ resources \ views \ admin \ post \ edit.blade.php

请帮助我,谢谢!

1 个答案:

答案 0 :(得分:1)

您将代码放置在错误的位置:

尝试一下:

<div class="form-group">
    <label for="tags">Select Tags</label>
    <select multiple class="form-control" name="tags[]" id="tags">
        @foreach($tags as $id => $name)
        <option id="{{ $id }}" {{ in_array($id,$post->category()->pluck('id')->toArray()) ? 'selected' : '' }}>{{ $name }}</option>
        @endforeach
    </select>
</div>