Laravel-livewire:为啥触发事件会执行 render() 方法?
Posted
技术标签:
【中文标题】Laravel-livewire:为啥触发事件会执行 render() 方法?【英文标题】:Laravel-livewire: Why does firing an event execute the render() method?Laravel-livewire:为什么触发事件会执行 render() 方法? 【发布时间】:2020-12-01 13:15:55 【问题描述】:这是 Laravel 的 Livewire 框架
html:
<button wire:click="$emit('postAdded')">
php:
protected $listeners = ['postAdded' => 'showPostAddedMessage'];
public function showPostAddedMessage()
// Do stuff
public function render()
return view('livewire.index');
单击按钮调用 showPostAddedMessage() 并在此之后调用 render()。如何在不调用 render() 的情况下监听事件?
【问题讨论】:
这就是 livewire 的工作原理。每当您更改任何内容/触发任何事件时。组件将刷新。据我所知,没有办法阻止它,除非你将 die() 放在 showPOstAddedMessage 函数中,这将是一种非常奇怪的解决方法。 @fahim152 哦,这很有道理。我必须将加载消息的部分和发送消息的部分分开。非常感谢!您能否也发表您的评论作为答案,以便我将其标记为已解决? :) 我通过嵌套 2 个组件解决了我的问题。父组件触发一个事件,子组件没有更新,这正是我想要的! 恭喜....我不这么认为。顺便说一句,很棒的解决方案...我的评论不是解决方案。它只是一个评论。它并没有解决你正在寻找的兄弟。如果您在答案部分写下您的解决方案,这样其他人将来可以得到帮助,那就太好了:) @fahim152 触发事件是刷新组件的原因,您的话和我的问题的答案(不是我的问题!!!)所以请添加这个作为答案:))跨度> 【参考方案1】:这就是 livewire 的工作原理。每当您更改任何内容/触发任何事件时。组件将刷新。据我所知,没有办法阻止它,除非您将 die() 放在 showPOstAddedMessage 函数中,这将是一种非常奇怪的解决方法。
【讨论】:
【参考方案2】:我遇到了同样的问题。就我而言, render() 方法正在关闭我的父模式框。我刚刚在模态 div 中添加了“wire:ignore”。 Livewire 在调用 render() 方法时会忽略该 div
【讨论】:
每次我从调用的下拉渲染方法中选择任何项目时,我假设播放视频的特定 div 都会消失,所以我将 wire:ignore 放在那个 div 上,它就可以工作了。 谢谢,这正是我想要的 :)【参考方案3】:我遇到了这种 hack:如果您担心不重新渲染视图,您可以从 render()
返回一个空字符串。 DOM 不会更新。
我的情况:我有一个不应该渲染任何东西的下载方法。
public function download()
$this->skipRender();
public function render()
if($this->shouldSkipRender)
return '';
return view("xxxxx");
只要我没有遗漏任何东西,这对我有用。
【讨论】:
谢谢,您也可以在 livewire 组件的第一个 div 中添加“wire:ignore” :)以上是关于Laravel-livewire:为啥触发事件会执行 render() 方法?的主要内容,如果未能解决你的问题,请参考以下文章