开发者问题收集

从子级向父级发送 laravel livewire 事件会导致指纹错误

2020-11-10
1788

从子容器向父容器发送 事件 时出现此错误。我按照建议使用 wire:key ,但出现 JS 错误 无法读取 null 的属性“指纹” 。知道我做错了什么吗?请参阅下面的示例。

容器

class Container extends Component
{
    public $listeners = [
        'submit'
    ];

    public function render()
    {
        return view('livewire.container');
    }

    public function submit()
    {
        //dd("The child says wow - it works!");
    }
}

带视图

<div>
    <h1>Im the container</h1>
    @foreach([1,2,3] as $nbr)
        @livewire('child', compact('nbr'))
    @endforeach
</div>

子容器

class Child extends Component
{
    public $nbr;

    public function mount($nbr)
    {
        $this->nbr = $nbr;
    }

    public function render()
    {
        return view('livewire.child');
    }

    public function submit()
    {
        $this->emit('submit', 'wow!');
    }
}

带视图

<div wire:key="{{ $nbr }}">
    Hey im a child
    <button wire:click="submit">submit</button>
</div>
1个回答

在循环中定义 Livewire 组件时,您需要为它们提供一个键,以便 Livewire 可以跟踪每个单独的组件。

<div>
    <h1>Im the container</h1>
    @foreach([1,2,3] as $key=>$nbr)
        @livewire('child', compact('nbr'), key($nbr))
    @endforeach
</div>

这是在组件上完成的,而不是在视图中的根元素上完成的,这意味着它被错误地放置在 wire:key="{{ $nbr }}" 在您的子视图中。

Qirel
2020-11-10