如何在 Svelte 中使用 RXJs 主题之类的存储变量?您可以在 Svelte 中使用带有 $ 前缀的 Subject 变量。但是当您将变量绑定到输入时,它会引发异常:“错误:name.set 不是函数”,因为 Subject 类型没有 set 方法。
问问题
133 次
1 回答
0
您可以在 Svelte 中像存储变量一样使用 RxJs Subject,如下例所示。
<script>
import {Subject} from "rxjs";
let name = new Subject();
setTimeout(()=>{name.next("text")}, 1000);
</script>
<h1>Hello {$name}!</h1>
但是,如果您尝试将name
变量与bind
指令一起使用,则会引发异常:“错误:name.set 不是函数”。
<script>
import {Subject} from "rxjs";
let name = new Subject();
$: console.log($name);
</script>
<h1>Hello {$name}!</h1>
<input bind:value={$name} />
要解决这个问题,您可以通过一个简单的技巧向 Subject 类添加一个 set 方法:)。
<script>
import {Subject} from "rxjs";
Subject.prototype.set = function (value) {
this.next(value);
}
let name = new Subject();
$name = "Ali";
$: console.log($name);
</script>
<h1>Hello {$name}!</h1>
<input bind:value={$name} />
于 2021-05-23T17:24:19.997 回答