我创建了三个表:
ID - 标题 - 体
ID - 名称
POST_ID - TAG_ID
public function tags()
{
return $this->belongsToMany('App\Tag');
}
public function posts()
{
return $this->belongsToMany('App\Post');
}
这是多对多的关系
我想在更新帖子时添加新帖子和更新标签时存储标签,并且我使用bootstrap-tagsinput插件,添加帖子,我使用此方法存储新标签:
public function storeTags($post, $tags)
{
$tagInputArr = explode(',', $tags);
$tagArr = [];
foreach ($tagInputArr as $tag) {
$tagArr[] = new Tag(['name' => $tag]);
}
$post->tags()->saveMany($tagArr);
}
$ post是新的post对象,$ tags是来自$ request的标记字符串。
对于更新帖子,我有一个问题,当我查看编辑帖子页面时,从数据库中选择默认标签,如果我想添加新标签,则storeTags方法不起作用。
答案 0 :(得分:1)
在storeTags()
$post->save();
if (isset($request->tags)) {
$post->tags()->sync($request->tags, false);
} else {
$post->tags()->sync(array());
}
在updateTags()
$post->save();
if (isset($request->tags)) {
$post->tags()->sync($request->tags);
} else {
$post->tags()->sync(array());
}
在你的标签的html文件中,使用这个
<select class="form-control select2-multi" name="tags[]" multiple="multiple">
@foreach ($tags as $tag)
<option value="{{ $tag->id }}">{{ $tag->name }}</option>
@endforeach
</select>
在sync()
更新方法中存在差异,不需要第二个参数。
我建议你watch这个标签制作的整个播放列表