diff --git a/docs/guides/forms.md b/docs/guides/forms.md index 4f1e912da..aed5d373c 100644 --- a/docs/guides/forms.md +++ b/docs/guides/forms.md @@ -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 `
` 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 `` 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 `` 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 ( + + ); + } +} +``` + +For more check out the docs for [form-association in +Stencil](../components/form-associated.md). ## Advanced forms diff --git a/versioned_docs/version-v4.5/guides/forms.md b/versioned_docs/version-v4.5/guides/forms.md index 4f1e912da..aed5d373c 100644 --- a/versioned_docs/version-v4.5/guides/forms.md +++ b/versioned_docs/version-v4.5/guides/forms.md @@ -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 `` 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 `` 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 `` 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 ( + + ); + } +} +``` + +For more check out the docs for [form-association in +Stencil](../components/form-associated.md). ## Advanced forms diff --git a/versioned_docs/version-v4.6/guides/forms.md b/versioned_docs/version-v4.6/guides/forms.md index 4f1e912da..aed5d373c 100644 --- a/versioned_docs/version-v4.6/guides/forms.md +++ b/versioned_docs/version-v4.6/guides/forms.md @@ -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 `` 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 `` 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 `` 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 ( + + ); + } +} +``` + +For more check out the docs for [form-association in +Stencil](../components/form-associated.md). ## Advanced forms diff --git a/versioned_docs/version-v4.7/guides/forms.md b/versioned_docs/version-v4.7/guides/forms.md index 4f1e912da..aed5d373c 100644 --- a/versioned_docs/version-v4.7/guides/forms.md +++ b/versioned_docs/version-v4.7/guides/forms.md @@ -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 `` 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 `` 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 `` 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 ( + + ); + } +} +``` + +For more check out the docs for [form-association in +Stencil](../components/form-associated.md). ## Advanced forms