【发布时间】:2020-06-24 07:17:19
【问题描述】:
我有两个组件 Posts 和 Post,Posts 显示帖子,通过点击图片我想在另一个组件中显示点击帖子的数据。
在下面发布类和组件:
组件视图:
<div class="post" x-data="{open:false}">
@foreach($posts as $post)
<div>
<h1>{{ $post->name }}</h1>
<h3>{{ $post->body }}</h3>
<img @click="open = !open" wire:click="showPost({{ $post->id }})" src="{{ $post->image }}" alt="">
</div>
@endforeach
<livewireL:post>
</div>
组件类:
class Posts extends Component
{
public $posts, $post;
public function mount(){
$this->posts = Post::all();
}
public function showPost($id){
$post = Post::find($id);
$this->post = $post;
}
public function render()
{
return view('livewire.posts');
}
}
这是我想在这个组件中显示点击数据的Post组件和类,我尝试了$emit和许多作为文档但没有结果。
我要呈现该数据的组件视图:
<div x-show="open">
<h1>{{ $post->name }}</h1>
<h3>{{ $post->body }}</h3>
<img src="{{ $post->image }}">
</div>
我要传递数据的类:
class Post extends Component
{
public $post;
public function mount($id)
{
$this->post = \App\Post::find($id);
}
public function render()
{
return view('livewire.post');
}
}
【问题讨论】: