From 3c2d36866a8f56a36f7a2d65cf5a15d4a1fbb50c Mon Sep 17 00:00:00 2001 From: Luke Latham <1622880+guardrex@users.noreply.github.com> Date: Fri, 16 Dec 2022 04:52:51 -0600 Subject: [PATCH] Custom elements updates (#27919) --- aspnetcore/blazor/components/index.md | 43 ++++++++++++++++++--------- 1 file changed, 29 insertions(+), 14 deletions(-) diff --git a/aspnetcore/blazor/components/index.md b/aspnetcore/blazor/components/index.md index 6e558d6977..5101a4c85d 100644 --- a/aspnetcore/blazor/components/index.md +++ b/aspnetcore/blazor/components/index.md @@ -1554,10 +1554,10 @@ builder.RootComponents.RegisterCustomElement("my-counter"); ### Use the registered custom element -Use the custom element with any web framework. For example, the preceding `my-counter` custom HTML element is used in a React app with the following markup: +Use the custom element with any web framework. For example, the preceding `my-counter` custom HTML element that renders the app's `Counter` component is used in a React app with the following markup: ```html - + ``` For a complete example of how to create custom elements with Blazor, see the [`CustomElementsComponent` component](https://github.com/dotnet/aspnetcore/blob/main/src/Components/test/testassets/BasicTestApp/CustomElementsComponent.razor) in the reference source. @@ -1568,30 +1568,45 @@ For a complete example of how to create custom elements with Blazor, see the [`C Pass parameters to your Blazor component either as HTML attributes or as JavaScript properties on the DOM element. -Consider the following integer parameter declaration: +The following `Counter` component uses an `IncrementAmount` parameter to set the increment amount of the **:::no-loc text="Click me":::** button. -```csharp -[Parameter] -public int IncrementAmount { get; set; } +`Pages/Counter.razor`: + +```razor +@page "/counter" + +

Counter

+ +

Current count: @currentCount

+ + + +@code { + private int currentCount = 0; + + [Parameter] + public int IncrementAmount { get; set; } = 1; + + private void IncrementCount() + { + currentCount += IncrementAmount; + } +} ``` -Pass a value to the preceding parameter as an HTML attribute: +Render the `Counter` component with the custom element and pass a value to the `IncrementAmount` parameter as an HTML attribute. The attribute name adopts kebab-case syntax (`increment-amount`, not `IncrementAmount`): ```html - + ``` -The attribute name adopts kebab-case syntax (`increment-amount`, not `IncrementAmount`). - -Alternatively, you can set the parameter's value as a JavaScript property on the element object: +Alternatively, you can set the parameter's value as a JavaScript property on the element object. The property name adopts camel case syntax (`incrementAmount`, not `IncrementAmount`): ```javascript const elem = document.querySelector("my-counter"); -elem.incrementAmount = 123; +elem.incrementAmount = 10; ``` -The property name adopts camel case syntax (`incrementAmount`, not `IncrementAmount`). - You can update parameter values at any time using either attribute or property syntax. Supported parameter types: