Releases: alpinejs/alpine
Releases · alpinejs/alpine
v2.2.0
Added
$watch('prop', callback)
has been added for watching data property changes.
<div x-data="{ open: false }" x-init="$watch('open', value => console.log(value))">
<button @click="open = ! open">Toggle Open</button>
</div>
(In the example, if the button is clicked, the value will be echoed out)
v2.1.1
Added
- The ability to reference just the method reference in an event handler:
// Before
<div x-data={ foo(e) { console.log(e) } }>
<button x-on:click="foo($event)">log event</button>
</div>
// After
<div x-data={ foo(e) { console.log(e) } }>
<button x-on:click="foo">log event</button>
</div>
Fixed
v2.1.0
Fixed
- Swapped out the hand-rolled reactivity engine for Salesforce's
observable-membrane
package #230 - If an element registers a global event listener (like
x-on:click.window
), it will be removed when the element is removed from the DOM - Add
open
to list of "boolean" attributes for data binding
v2.0.2
Fixed
- For
(item, index, group) in items
,index
andgroup
weren't being made available to elements inside anx-for
<template>
tag. Now they are #208
<div x-data="{ items: ['foo'] }">
<template x-for="(item, index) in items">
<div>
<h1 x-text="items.indexOf(item)"></h1>
// Same as...
<h2 x-text="index"></h2>
</div>
</template>
</div>
- Using
x-for
andx-if
in conjunction (<template x-for="..." x-if="...">
) resulted in odd behavior. It is now fully possible and supported #208
<div x-data="{ items: ['foo', 'bar'], show: false }">
<button @click="show = ! show"></button>
<template x-if="show" x-for="item in items">
<span x-text="item"></span>
</template>
</div>
v2.0.0
Removed
x-created
andx-mounted
in favor ofx-init
Forx-created
behavior, usex-init
. Forx-mounted
behavior, return a callback fromx-init
Before
<div x-data x-created="doSomething()">
...
<div x-data x-mounted="doSomething()">
After
<div x-data x-init="doSomething()">
...
<div x-data x-init="() => { doSomething() }">
v1.12.0
Added
x-show.transition
API
# Default to scale .95->1, opacity 0->1, cubic-bezier(0.4, 0.0, 0.2, 1), 150ms in, 75ms out
x-show.transition
# Only transition opacity
x-show.transition.opacity
# Only transition in
x-show.transition.in
x-show.transition.out
# Only transition scale
x-show.transition.scale
# Customize scale
x-show.transition.scale.95
# Set Duration (automatically sets the "out" duration to half the in)
x-show.transition.duration.150ms
# If you don't like this, you can do this:
# Note: if both "in" AND "out" are applied, they are treated as two
# seperate transition setting groups. Full flexibility.
x-show.transition.in.duration.150ms.out.duration.150ms
# Set origin
x-show.transition.origin.top
# Set multiple origins
x-show.transition.origin.top.left
# All of these settings can be combined to create something rediculous like this:
x-show.transition.in.opacity.duration.150ms.out.opacity.scale.80.duration.500ms.origin.bottom.right
v1.11.1
Fixed
- Nesting x-show's was broken.
v1.11.0
v1.10.1
Fixed
.once
event listener modifier wasn't honoring newreturn false
ability of listeners.