gpt4 book ai didi

reactjs - RactiveJS 和 JSX

转载 作者:行者123 更新时间:2023-12-02 05:37:06 27 4
gpt4 key购买 nike

RactiveJS 与 JSX 兼容吗?

我猜有些标记不兼容。我喜欢强类型的想法,并且能够在 JavaScript 源代码中干净地编写模板。也许这被认为是糟糕的设计?

最佳答案

没有。 React.js 和 Ractive.js 有许多相似之处(例如,两者都通过在内存中构建轻量级虚拟 DOM 来工作),但它们有一个非常重要的区别 - React 完全拒绝模板的想法。

也就是说 JSX 不是一种模板语言,它只是看起来像一种!在 React 中,如果你有这样的事情......

<h1>Hello world!</h1>

...它被 JSX 预处理器转换成这样的东西:

React.DOM.h1(null, 'Hello world!');

换句话说,JSX 描述的是函数,而不是模板。相比之下,在 Ractive 中,Mustache 模板被解析为可以作为 JSON 传输的树状结构。

现在,在这个例子中,原始字符串经过什么过程并不重要——它仍然会以 <h1> 结束。某处浏览器中的元素。但是,当您开始引入引用 this.state 的任意 JavaScript 时,它会变得更加困难。和 this.props - 可以改变 React 中组件的基本结构,但在 Ractive 中没有意义的东西。

Ractive 将来可能会支持除 Mustache 之外的模板语言,但 JSX 不太可能是其中之一,因为它们具有如此不同的方法和设计目标。

但是这里有一个相关的问题,即能够在单个文件中完整描述组件。有一些 ongoing work发生在那里 - 最有可能的情况是我们将能够在 .html 文件中描述组件(因为您可以在 HTML 中使用 JavaScript 和 CSS),而不是将模板写入您的 .js 文件。

关于reactjs - RactiveJS 和 JSX,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20737863/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com