forked from livewire/docs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
events.blade.php
executable file
·198 lines (144 loc) · 6.27 KB
/
events.blade.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
* [Firing Events](#firing-events) { .text-blue-800 }
* [From The Template](#from-template) { .font-normal.text-sm.text-blue-800 }
* [From The Component](#from-component) { .font-normal.text-sm.text-blue-800 }
* [From Global JavaScript](#from-js) { .font-normal.text-sm.text-blue-800 }
* [Event Listeners](#event-listeners) { .text-blue-800 }
* [Passing Parameters](#passing-parameters) { .text-blue-800 }
* [Scoping Events](#scoping-events) { .text-blue-800 }
* [Scoping To Parent Listeners](#scope-to-parents) { .font-normal.text-sm.text-blue-800 }
* [Scoping To Components By Name](#scope-by-name) { .font-normal.text-sm.text-blue-800 }
* [Scoping To Self](#scope-to-self) { .font-normal.text-sm.text-blue-800 }
* [Listening For Events In JavaScript](#in-js) { .text-blue-800 }
* [Dispatching Browser Events](#browser) { .text-blue-800 }
<div> </div>
@include('includes.screencast-cta')
Livewire components can communicate with each other through a global event system. As long as two Livewire components are living on the same page, they can communicate using events and listeners.
## Firing Events {#firing-events}
There are multiple ways to fire events from Livewire components.
### Method A: From The Template {#from-template}
@component('components.code')
<button wire:click="$emit('postAdded')">
@endcomponent
### Method B: From The Component {#from-component}
@component('components.code', ['lang' => 'php'])
$this->emit('postAdded');
@endcomponent
### Method C: From Global JavaScript {#from-js}
@component('components.code', ['lang' => 'javascript'])
<script>
Livewire.emit('postAdded')
</script>
@endcomponent
## Event Listeners {#event-listeners}
Event listeners are registered in the `$listeners` property of your Livewire components.
Listeners are a key->value pair where the key is the event to listen for, and the value is the method to call on the component.
@component('components.code', ['lang' => 'php'])
class ShowPosts extends Component
{
public $postCount;
protected $listeners = ['postAdded' => 'incrementPostCount'];
public function incrementPostCount()
{
$this->postCount = Post::count();
}
}
@endcomponent
Now when any other component on the page emits a `postAdded` event, this component will pick it up and fire the `incrementPostCount` method on itself.
@component('components.tip')
If the name of the event and the method you're calling match, you can leave out the key. For example: <code>protected $listeners = ['postAdded'];</code> will call the <code>postAdded</code> method when the <code>postAdded</code> event is emitted.
@endcomponent
If you need to name event listeners dynamically, you can substitute the `$listeners` property for the `getListeners()` protected method on the component:
@component('components.code-component')
@slot('class')
class ShowPosts extends Component
{
public $postCount;
protected function getListeners()
{
return ['postAdded' => 'incrementPostCount'];
}
...
}
@endslot
@endcomponent
## Passing Parameters {#passing-parameters}
You can also send parameters with an event emission.
@component('components.code', ['lang' => 'php'])
$this->emit('postAdded', $post->id);
@endcomponent
@component('components.code-component')
@slot('class')
class ShowPosts extends Component
{
public $postCount;
public $recentlyAddedPost;
protected $listeners = ['postAdded'];
public function postAdded(Post $post)
{
$this->postCount = Post::count();
$this->recentlyAddedPost = $post;
}
}
@endslot
@endcomponent
## Scoping Events {#scoping-events}
### Scoping To Parent Listeners {#scope-to-parents}
When dealing with [nested components](nesting-components), sometimes you may only want to emit events to parents and not children or sibling components.
In these cases, you can use the `emitUp` feature:
@component('components.code', ['lang' => 'php'])
$this->emitUp('postAdded');
@endcomponent
@component('components.code')
<button wire:click="$emitUp('postAdded')">
@endcomponent
### Scoping To Components By Name {#scope-by-name}
Sometimes you may only want to emit an event to other components of the same type.
In these cases, you can use `emitTo`:
@component('components.code', ['lang' => 'php'])
$this->emitTo('counter', 'postAdded');
@endcomponent
@component('components.code')
<button wire:click="$emitTo('counter', 'postAdded')">
@endcomponent
(Now, if the button is clicked, the "postAdded" event will only be emitted to `counter` components)
### Scoping To Self {#scope-to-self}
Sometimes you may only want to emit an event on the component that fired the event.
In these cases, you can use `emitSelf`:
@component('components.code', ['lang' => 'php'])
$this->emitSelf('postAdded');
@endcomponent
@component('components.code')
<button wire:click="$emitSelf('postAdded')">
@endcomponent
(Now, if the button is clicked, the "postAdded" event will only be emitted to the instance of the component that it was emitted from.)
## Listening For Events In JavaScript {#in-js}
Livewire allows you to register event listeners in JavaScript like so:
@component('components.code', ['lang' => 'javascript'])
<script>
Livewire.on('postAdded', postId => {
alert('A post was added with the id of: ' + postId);
})
</script>
@endcomponent
@component('components.tip')
This feature is actually incredibly powerful. For example, you could register a listener to show a toaster (popup) inside your app when Livewire performs certain actions. This is one of the many ways to bridge the gap between PHP and JavaScript with Livewire.
@endcomponent
## Dispatching Browser Events {#browser}
Livewire allows you to fire browser window events like so:
@component('components.code', ['lang' => 'php'])
$this->dispatchBrowserEvent('name-updated', ['newName' => $value]);
@endcomponent
You are able to listen for this window event with JavaScript:
@component('components.code', ['lang' => 'javascript'])
<script>
window.addEventListener('name-updated', event => {
alert('Name updated to: ' + event.detail.newName);
})
</script>
@endcomponent
AlpineJS allows you to easily listen for these window events within your HTML:
@component('components.code', ['lang' => 'html'])
<div x-data="{ open: false }" @name-updated.window="open = false">
<!-- Modal with a Livewire name update form -->
</div>
@endcomponent