Skip to content

Commit

Permalink
docs(forms): add a small section with a FACE example
Browse files Browse the repository at this point in the history
  • Loading branch information
alicewriteswrongs committed Nov 6, 2023
1 parent b0bd087 commit 93c93e2
Show file tree
Hide file tree
Showing 4 changed files with 176 additions and 0 deletions.
44 changes: 44 additions & 0 deletions docs/guides/forms.md
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,50 @@ export class MyName {

Let's go over what is happening here. First we bind the value of the input to a state variable, in this case `this.value`. We then set our state variable to the new value of the input with the `handleChange` method we have bound to `onInput`. `onInput` will fire every keystroke that the user types into the input.

## Using form-associated custom elements

In addition to using a `<form>` element inside of a Stencil component, as shown
in the above example, you can also use Stencil's support for building
form-associated custom elements to create a Stencil component that integrates
in a native-like way with a `<form>` tag _around_ it. This allows you to build
rich form experiences using Stencil components which leverage built-in form
features like validation and accessibility.

As an example, translating the above example to be a form-associated component
(instead of one which includes a `<form>` element in its JSX) would look like
this:

```tsx
@Component({
tag: 'my-name',
styleUrl: 'my-name.css',
formAssociated: true
})
export class MyName {
@State() value: string;
@AttachInternals() internals: ElementInternals;

handleChange(event) {
this.internals.setFormValue(event.target.value);
}

render() {
return (
<label>
Name:
<input
type="text"
value={this.value}
onInput={(event) => this.handleChange(event)}
/>
</label>
);
}
}
```

For more check out the docs for [form-association in
Stencil](../components/form-associated.md).

## Advanced forms

Expand Down
44 changes: 44 additions & 0 deletions versioned_docs/version-v4.5/guides/forms.md
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,50 @@ export class MyName {

Let's go over what is happening here. First we bind the value of the input to a state variable, in this case `this.value`. We then set our state variable to the new value of the input with the `handleChange` method we have bound to `onInput`. `onInput` will fire every keystroke that the user types into the input.

## Using form-associated custom elements

In addition to using a `<form>` element inside of a Stencil component, as shown
in the above example, you can also use Stencil's support for building
form-associated custom elements to create a Stencil component that integrates
in a native-like way with a `<form>` tag _around_ it. This allows you to build
rich form experiences using Stencil components which leverage built-in form
features like validation and accessibility.

As an example, translating the above example to be a form-associated component
(instead of one which includes a `<form>` element in its JSX) would look like
this:

```tsx
@Component({
tag: 'my-name',
styleUrl: 'my-name.css',
formAssociated: true
})
export class MyName {
@State() value: string;
@AttachInternals() internals: ElementInternals;

handleChange(event) {
this.internals.setFormValue(event.target.value);
}

render() {
return (
<label>
Name:
<input
type="text"
value={this.value}
onInput={(event) => this.handleChange(event)}
/>
</label>
);
}
}
```

For more check out the docs for [form-association in
Stencil](../components/form-associated.md).

## Advanced forms

Expand Down
44 changes: 44 additions & 0 deletions versioned_docs/version-v4.6/guides/forms.md
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,50 @@ export class MyName {

Let's go over what is happening here. First we bind the value of the input to a state variable, in this case `this.value`. We then set our state variable to the new value of the input with the `handleChange` method we have bound to `onInput`. `onInput` will fire every keystroke that the user types into the input.

## Using form-associated custom elements

In addition to using a `<form>` element inside of a Stencil component, as shown
in the above example, you can also use Stencil's support for building
form-associated custom elements to create a Stencil component that integrates
in a native-like way with a `<form>` tag _around_ it. This allows you to build
rich form experiences using Stencil components which leverage built-in form
features like validation and accessibility.

As an example, translating the above example to be a form-associated component
(instead of one which includes a `<form>` element in its JSX) would look like
this:

```tsx
@Component({
tag: 'my-name',
styleUrl: 'my-name.css',
formAssociated: true
})
export class MyName {
@State() value: string;
@AttachInternals() internals: ElementInternals;

handleChange(event) {
this.internals.setFormValue(event.target.value);
}

render() {
return (
<label>
Name:
<input
type="text"
value={this.value}
onInput={(event) => this.handleChange(event)}
/>
</label>
);
}
}
```

For more check out the docs for [form-association in
Stencil](../components/form-associated.md).

## Advanced forms

Expand Down
44 changes: 44 additions & 0 deletions versioned_docs/version-v4.7/guides/forms.md
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,50 @@ export class MyName {

Let's go over what is happening here. First we bind the value of the input to a state variable, in this case `this.value`. We then set our state variable to the new value of the input with the `handleChange` method we have bound to `onInput`. `onInput` will fire every keystroke that the user types into the input.

## Using form-associated custom elements

In addition to using a `<form>` element inside of a Stencil component, as shown
in the above example, you can also use Stencil's support for building
form-associated custom elements to create a Stencil component that integrates
in a native-like way with a `<form>` tag _around_ it. This allows you to build
rich form experiences using Stencil components which leverage built-in form
features like validation and accessibility.

As an example, translating the above example to be a form-associated component
(instead of one which includes a `<form>` element in its JSX) would look like
this:

```tsx
@Component({
tag: 'my-name',
styleUrl: 'my-name.css',
formAssociated: true
})
export class MyName {
@State() value: string;
@AttachInternals() internals: ElementInternals;

handleChange(event) {
this.internals.setFormValue(event.target.value);
}

render() {
return (
<label>
Name:
<input
type="text"
value={this.value}
onInput={(event) => this.handleChange(event)}
/>
</label>
);
}
}
```

For more check out the docs for [form-association in
Stencil](../components/form-associated.md).

## Advanced forms

Expand Down

1 comment on commit 93c93e2

@vercel
Copy link

@vercel vercel bot commented on 93c93e2 Nov 6, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Successfully deployed to the following URLs:

stencil-docs – ./

stencil-site.vercel.app
stencil-docs-git-main-ionic1.vercel.app
stencil-docs-ionic1.vercel.app

Please sign in to comment.