Still loading... You can interact in this page after it's fully loaded/connected.

Current page is prerendered.

About

Adaptive is based on FSharp.Data.Adaptive. In Fun.Blazor, we only use a very small piece of its power ChangableValue, and the result is already great. For its core concept, you can check their documentation.

In Fun.Blazor, we use it to isolate dynamic UI parts. Because most of the time, your data changes will only affect a specific part of the whole UI. So you can define things like the following:

let yourUI =
    div {
        style { ... }
        ... a lot of stuff
        adapt {
            let! msg = from store
            // only below part will be rerendered.
            div {
                style { ... }
                msg
            }
        } 
        ... a lot of stuff
    }

Please remember, the adaptive model is optional. If you do not like it, you can use your own model.

You may notice that you can also do the following, and it may look cleaner from a different point of view. But DisableEventTriggerStateHasChanged is turned on by default. The reason is to reduce the calculation of the virtual dom. With adaptiview, we can narrow the dom to a specific part for recalculating the dom in an isolated way. If you check the Form documentation, you will see it uses this pattern a lot. With that, we can have better performance for large UI dom trees.

Count=0

And adaptiview can also accept parameters like isStatic/key. With this, even if you re-call yourUI, it will not affect the isolated part.

Number1: 1. (Will change when click Number1)
Number2: 2. (Will change when click Number2. And will be reset when click Number1)
Number1: 1. (Will not change, because it is a value type)
Number1.Value: 1. (Will update to the current Number1 when click Number3. Because it is a reference type)
Number3: 3. (Will change when click Number3
1/2/2025 1:23:26 AM
1/2/2025 1:23:26 AM