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() 方法?的主要内容,如果未能解决你的问题,请参考以下文章

JS的节流和防抖

小程序用户操作事件

jquery为啥触发多次click事件

为啥onchange事件触发不了?求高手指教

为啥小弟我的canvas的鼠标事件不会触发

将文件上传到 Azure Blob 存储时没有触发事件网格事件——为啥?