Fable.Haunted 1.0.0
dotnet add package Fable.Haunted --version 1.0.0
NuGet\Install-Package Fable.Haunted -Version 1.0.0
此命令旨在在 Visual Studio 的包管理器控制台中使用,因为它使用 NuGet 模块的 Install-Package。
<PackageReference Include="Fable.Haunted" Version="1.0.0" />
对于支持 PackageReference 的项目,将此 XML 节点复制到项目文件以引用此包。
paket add Fable.Haunted --version 1.0.0
NuGet 团队不提供对该客户端的支持。请联系其 管理员 以获取支持。
#r "nuget: Fable.Haunted, 1.0.0"
#r 指令可用于 F# Interactive 和多语言 Notebooks。将此内容复制到交互式工具或脚本的源代码中,以引用包。
// Install Fable.Haunted as a Cake Addin #addin nuget:?package=Fable.Haunted&version=1.0.0 // Install Fable.Haunted as a Cake Tool #tool nuget:?package=Fable.Haunted&version=1.0.0
NuGet 团队不提供对该客户端的支持。请联系其 管理员 以获取支持。
Fable.Haunted
字符串太多? 了解 VSCode 中 html 突出显示 vscode-template-fsharp-highlight
在此处查看库的实际效果 这里
Lit 只会重新渲染您的模板中更改的部分,其余部分将保持不变!
module Main
open Browser.Types
open Lit
open Haunted
open Haunted.Types
open Fable.Core
open Controllers
JsInterop.importSideEffects "./styles.css"
type EventTarget with
member this.Value = (this :?> HTMLInputElement).value
type Msg =
| Increment
| Decrement
| Reset
let private custom_element
(props: {| sample: string option
complexValues: {| message: string |} option |})
=
let value =
props.complexValues
|> Option.defaultValue {| message = "default message" |}
let mouseCtrl =
Haunted.useController<MouseController> (fun host -> MouseController(host) :> ReactiveController)
let sample = defaultArg props.sample "default sample"
html
$"""
<p>A! {sample} - {value.message}</p>
<p>
You can use reactive controllers too!
<br>
Mouse Position: x - {mouseCtrl.x}, y - {mouseCtrl.y}
</p>
"""
// defineComponent registers a Custom Element so you don't need to actually
// call this function inside any component, you can use the component itself
defineComponent
"inner-component"
(Haunted.Component(
custom_element,
// if you want to monitor attributes you need to pass an array of attribute names
// these will become available in the function's first argument
// also these components can be simple custom elements without shadow DOM
// if you choose not to use shadow DOM you can use normal css stylesheets like bulma or bootstrap
{| observedAttributes = [| "sample" |]
useShadowDOM = false |}
))
// by itself lit-html functions are stateless
let private aStatelessFunction paramA paramB =
html
$"""
<div>A standard stateless Lit Template!</div>
this will re-render when the parameters change: {paramA} - {paramB}
"""
let private elmishLike: Reducer<int, Msg> =
fun state action ->
match action with
| Increment -> state + 1
| Decrement -> state - 1
| Reset -> 0
// we can use haunted to add state to our components
let private app () =
let state, dispatch = Haunted.useReducer (elmishLike, 0)
let log =
Haunted.useCallback ((fun x -> printfn "%s" x), [| state |])
let clockCtrl =
Haunted.useController<ClockController> (fun host -> ClockController(host, 1000) :> ReactiveController)
log $"{state}"
let complex =
{| message = $"Complex object message value: {state}" |}
html
$"""
<h1>Hello, World! - {clockCtrl.time.ToLongTimeString()}</h1>
<inner-component sample={$"Attribute value: {state}"} .complexValues={complex}></inner-component>
{aStatelessFunction "value" state}
<section>
<p>Counter: {state}</p>
<button @click="{fun _ -> dispatch Increment}">Increment</button>
<button @click="{fun _ -> dispatch Decrement}">Decrement</button>
<button @click="{fun _ -> dispatch Reset}">Reset</button>
</section>
"""
defineComponent "fable-app" (Haunted.Component(app, {| useShadowDOM = false |}))
产品 | 版本 兼容和额外的计算目标框架版本。 |
---|---|
.NET | net5.0 已计算。 net5.0-windows 已计算。 net6.0 已计算。 net6.0-android 已计算。 net6.0-ios 已计算。 net6.0-maccatalyst 已计算。 net6.0-macos 已计算。 net6.0-tvos 已计算。 net6.0-windows 已计算。 net7.0 已计算。 net7.0-android 已计算。 net7.0-ios 已计算。 net7.0-maccatalyst 已计算。 net7.0-macos 已计算。 net7.0-tvos 已计算。 net7.0-windows 已计算。 net8.0 已计算。 net8.0-android 已计算。 net8.0-browser 已计算。 net8.0-ios 已计算。 net8.0-maccatalyst 已计算。 net8.0-macos 已计算。 net8.0-tvos 已计算。 net8.0-windows 已计算。 |
.NET Core | netcoreapp2.0 已计算。 netcoreapp2.1 已计算。 netcoreapp2.2 已计算。 netcoreapp3.0 已计算。 netcoreapp3.1 已计算。 |
.NET Standard | netstandard2.0 兼容。 netstandard2.1 已计算。 |
.NET Framework | net461 已计算。 net462 已计算。 net463 已计算。 net47 已计算。 net471 已计算。 net472 已计算。 net48 已计算。 net481 已计算。 |
MonoAndroid | monoandroid 已计算。 |
MonoMac | monomac 已计算。 |
MonoTouch | monotouch 已计算。 |
Tizen | tizen40 已计算。 tizen60 已计算。 |
Xamarin.iOS | xamarinios 已计算。 |
Xamarin.Mac | xamarinmac 已计算。 |
Xamarin.TVOS | xamarintvos 已计算。 |
Xamarin.WatchOS | xamarinwatchos 已计算。 |
-
.NETStandard 2.0
- Fable.Lit (>= 1.3.1)
- FSharp.Core (>= 6.0.0)
NuGet 包
此包未由任何 NuGet 包使用。
GitHub 仓库
此包未由任何流行的 GitHub 仓库使用。
版本 | 下载 | 最后更新 |
---|---|---|
1.0.0 | 392 | 11/7/2021 |
1.0.0-rc-001 | 218 | 9/23/2021 |
1.0.0-beta-007 | 292 | 8/29/2021 |
1.0.0-beta-006 | 229 | 8/28/2021 |