Skip to content

Commit

Permalink
📝 Updates docs with notes for x-data usage (alpinejs#4307)
Browse files Browse the repository at this point in the history
  • Loading branch information
ekwoka authored Oct 15, 2024
1 parent cfe9499 commit 1ab7b6b
Show file tree
Hide file tree
Showing 9 changed files with 23 additions and 4 deletions.
2 changes: 2 additions & 0 deletions packages/docs/src/en/directives/bind.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,8 @@ If `x-bind:` is too verbose for your liking, you can use the shorthand: `:`. For
<input type="text" :placeholder="placeholder">
```

> Despite not being included in the above snippet, `x-bind` cannot be used if no parent element has `x-data` defined. [→ Read more about `x-data`](/directives/data)
<a name="binding-classes"></a>
## Binding classes

Expand Down
4 changes: 3 additions & 1 deletion packages/docs/src/en/directives/for.md
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ You may also pass objects to `x-for`.

There are two rules worth noting about `x-for`:

>`x-for` MUST be declared on a `<template>` element.
> `x-for` MUST be declared on a `<template>` element.
> That `<template>` element MUST contain only one root element
<a name="keys"></a>
Expand Down Expand Up @@ -110,6 +110,8 @@ If you need to simply loop `n` number of times, rather than iterate through an a

`i` in this case can be named anything you like.

> Despite not being included in the above snippet, `x-for` cannot be used if no parent element has `x-data` defined. [→ Read more about `x-data`](/directives/data)
<a name="contents-of-a-template"></a>
## Contents of a `<template>`

Expand Down
3 changes: 2 additions & 1 deletion packages/docs/src/en/directives/id.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ title: id
---

# x-id

`x-id` allows you to declare a new "scope" for any new IDs generated using `$id()`. It accepts an array of strings (ID names) and adds a suffix to each `$id('...')` generated within it that is unique to other IDs on the page.

`x-id` is meant to be used in conjunction with the `$id(...)` magic.
Expand All @@ -30,4 +31,4 @@ Here's a brief example of this directive in use:
</div>
```


> Despite not being included in the above snippet, `x-id` cannot be used if no parent element has `x-data` defined. [→ Read more about `x-data`](/directives/data)
8 changes: 6 additions & 2 deletions packages/docs/src/en/directives/if.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,10 @@ Because of this difference in behavior, `x-if` should not be applied directly to
</template>
```

> Unlike `x-show`, `x-if`, does NOT support transitioning toggles with `x-transition`.
> Despite not being included in the above snippet, `x-if` cannot be used if no parent element has `x-data` defined. [→ Read more about `x-data`](/directives/data)
> Remember: `<template>` tags can only contain one root level element.
## Caveats

Unlike `x-show`, `x-if`, does NOT support transitioning toggles with `x-transition`.

`<template>` tags can only contain one root element.
2 changes: 2 additions & 0 deletions packages/docs/src/en/directives/model.md
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,8 @@ Now when the `<button>` is clicked, the input element's value will instantly be
</div>
<!-- END_VERBATIM -->

> Despite not being included in the above snippet, `x-model` cannot be used if no parent element has `x-data` defined. [→ Read more about `x-data`](/directives/data)
<a name="textarea-inputs"></a>
## Textarea inputs

Expand Down
2 changes: 2 additions & 0 deletions packages/docs/src/en/directives/on.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@ Here's the same component as above, but using the shorthand syntax instead:
<button @click="alert('Hello World!')">Say Hi</button>
```

> Despite not being included in the above snippet, `x-on` cannot be used if no parent element has `x-data` defined. [→ Read more about `x-data`](/directives/data)
<a name="the-event-object"></a>
## The event object

Expand Down
2 changes: 2 additions & 0 deletions packages/docs/src/en/directives/ref.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,3 +22,5 @@ title: ref
</div>
</div>
<!-- END_VERBATIM -->

> Despite not being included in the above snippet, `x-ref` cannot be used if no parent element has `x-data` defined. [→ Read more about `x-data`](/directives/data)
2 changes: 2 additions & 0 deletions packages/docs/src/en/directives/transition.md
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,8 @@ If you wish to customize the durations specifically for entering and leaving, yo
>
```

> Despite not being included in the above snippet, `x-transition` cannot be used if no parent element has `x-data` defined. [→ Read more about `x-data`](/directives/data)
<a name="customizing-delay"></a>
### Customizing delay

Expand Down
2 changes: 2 additions & 0 deletions packages/docs/src/en/start-here.md
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,8 @@ Everything in Alpine starts with an `x-data` directive. Inside of `x-data`, in p

Every property inside this object will be made available to other directives inside this HTML element. In addition, when one of these properties changes, everything that relies on it will change as well.

> `x-data` is required on a parent element for most Alpine directives to work.
[→ Read more about `x-data`](/directives/data)

Let's look at `x-on` and see how it can access and modify the `count` property from above:
Expand Down

0 comments on commit 1ab7b6b

Please sign in to comment.