Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/archtechx/livewire-petite-vue
petite-vue support for Livewire
https://github.com/archtechx/livewire-petite-vue
laravel livewire vue vuejs
Last synced: 3 months ago
JSON representation
petite-vue support for Livewire
- Host: GitHub
- URL: https://github.com/archtechx/livewire-petite-vue
- Owner: archtechx
- Created: 2021-07-10T18:11:18.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2021-07-13T18:27:14.000Z (over 3 years ago)
- Last Synced: 2024-09-30T04:41:31.168Z (4 months ago)
- Topics: laravel, livewire, vue, vuejs
- Language: JavaScript
- Homepage:
- Size: 10.7 KB
- Stars: 9
- Watchers: 2
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# petite-vue driver for Livewire
This package provides [petite-vue](https://github.com/vuejs/petite-vue) support for [Livewire](https://laravel-livewire.com).
## Installation
Currently it's only possible to use this library using a ``. Later we'd also like to support a self-initializing non-module `<script>` as well as an npm package.
```html
<script type="module">
import { createApp } from 'https://unpkg.com/@archtechx/livewire-petite-vue'window.addEventListener('livewire:load', () => {
createApp().mount()
})```
The imported `createApp` automatically includes a bit of global state and a `v-livewire` directive. If you'd like to do this manually, you can use:
```html
import { state, directive } from 'https://unpkg.com/@archtechx/livewire-petite-vue'
import { createApp } from 'https://unpkg.com/petite-vue?module'window.addEventListener('livewire:load', () => {
createApp(state).directive('livewire', directive).mount()
})```
## Usage
The package provides a `v-livewire` directive that lets you configure bidirectional links between Vue state and Livewire state.
For example, if you had a `messages` property in Vue and an `items` property in Livewire, you could do:
```html
```Note that you **always need to have the property in Vue as well**. You need some initial state, and your template must work with the empty state. In our case, an empty state for messages is just `{}`.
If the properties are named the same, you can simply pass an array:
```html
```If you'd like to defer value changes, i.e. have reactive state in Vue but only update Livewire backend state when a Livewire action is executed, you can use the `.defer` modifier:
```html
```After your bindings are configured, you can simply update state and the changes will sync between Vue and Livewire. Any changes done in Livewire will be reflected in Vue, and any changes done in Vue (e.g. via `v-model` inputs) will be reflected in Livewire.
That's the state. But Livewire can also call methods.
For that, you can simply use the `wire` proxy in your component's state:
```html
Send
```
If the methods return a value, you can do something like `await wire.foo('bar')`.
```html
You can use Vue-only state in the component: {{ foo }}
Message
Send
Remove
```## Things to note
Vue uses templates which contain `{{ these }}` things, and that doesn't pair with Livewire as well as Alpine.
For that reason, the library automatically adds `wire:ignore` to the root element of each petite-vue component.