- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试转换这个很酷的 <canvas>
我找到的动画here到 React 可重用组件中。看起来该组件需要一个用于 Canvas 的父组件,以及用于 function Ball()
的许多子组件。 .
出于性能原因,将Balls
设置为可能会更好。成无状态组件,因为它们有很多。我不太熟悉制作无状态组件,并且想知道应该在哪里定义 this.update()
和this.draw
function Ball()
中定义的函数.
无状态组件的函数是在组件内部还是外部?换句话说,以下哪一个更好?
1:
const Ball = (props) => {
const update = () => {
...
}
const draw = () => {
...
}
return (
...
);
}
2:
function update() {
...
}
function draw() {
...
}
const Ball = (props) => {
return (
...
);
}
每种方法都有哪些优点和缺点,其中一种更适合像我这样的特定用例?
最佳答案
首先要注意的是无状态功能组件不能有方法:您不应该指望调用 update
或draw
在渲染的 Ball
如果是无状态功能组件。
在大多数情况下,您应该在组件函数之外声明函数,这样您只需声明一次,并且始终重用相同的引用。当您在内部声明函数时,每次渲染组件时都会再次定义该函数。
在某些情况下,您需要在组件内定义一个函数,例如,将其分配为事件处理程序,该事件处理程序根据组件的属性表现不同。但您仍然可以在 Ball
之外定义该函数并将其与属性绑定(bind),使代码更加简洁并使update
或draw
可重用的函数:
// you can use update somewhere else
const update = (propX, a, b) => { ... };
const Ball = props => (
<Something onClick={update.bind(null, props.x)} />
);
如果您使用 Hook ,则可以使用useCallback
确保该函数仅在其任何依赖项发生更改时才重新定义(在本例中为 props.x
):
const Ball = props => {
const onClick = useCallback((a, b) => {
// do something with a, b and props.x
}, [props.x]);
return (
<Something onClick={onClick} />
);
}
这是错误的方式:
const Ball = props => {
function update(a, b) {
// props.x is visible here
}
return (
<Something onClick={update} />
);
}
当使用useCallback
时,定义update
useCallback
中的函数钩子(Hook)本身或组件外部成为最重要的设计决策:您应该考虑是否要重用 update
和/或如果您需要访问组件闭包的范围,例如读/写状态。就我个人而言,我选择默认将其定义在组件内部,并仅在需要时才使其可重用,以防止从一开始就过度设计。最重要的是,重用应用程序逻辑最好使用更具体的钩子(Hook)来完成,而将组件保留用于演示目的。使用钩子(Hook)时在组件外部定义函数实际上取决于您希望应用程序逻辑与 React 解耦的程度。
另一个common discussion关于useCallback
是是否总是将它用于每个功能。也就是说,视为选择加入或始终推荐。我认为始终使用 useCallback
:我见过许多由于未将函数包装在 useCallback
中而导致的错误并且在任何情况下这样做都不会以任何方式影响性能或逻辑。在大多数情况下,您希望在依赖项不更改的情况下保留引用,因此您可以使用函数本身作为其他效果、备忘录或回调的依赖项。在许多情况下,回调将作为 props 传递给其他元素,如果您使用 useCallback
来内存它您不会更改 Prop (从而重新渲染)其他组件,无论其成本有多低。我见过组件中声明的数千个函数,但没有一个使用 useCallback
的情况。会有任何不利的一面。另一方面,大多数函数都没有用 useCallback
来内存。如果开发人员没有意识到不这样做的影响,最终将被更改为这样做,从而导致严重的错误或性能问题。 技术上使用 useCallback
会影响性能,就像您将创建和附加函数一样,但与您使用 useCallback
总是必须发生的函数的重新声明相比,它可以忽略不计。与否以及 React 和 JavaScript 的总体足迹。因此,如果您确实关心 useCallback
的性能影响与不使用它相比,您应该问自己 React 是否是适合这项工作的工具。
关于javascript - 函数组件中的函数应该放在哪里?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46138145/
我当前项目中的许多类都有几个只能从类本身内部调用的属性和方法。此外,根据类(class)的当前状态,它们可能会扰乱类(class)的工作。 目前,所有这些接口(interface)都在 .h 文件的主
我想使用ngbTabSet将nav-pills in card-header 和tab-content in card-body。但我不知道该怎么做。 这是我尝试实现的示例(使用 bootstrap.
我正在浏览文档以查找如何允许放置在停靠栏图标上。据我所知,建议您使用 LSItemContentTypes,因为 CFBundleTypeOSTypes 已弃用。但是,我无法让 LSItemConte
我正在尝试在书签中使用 jquery UI 作为 slider 。并且 jquery ui 要求在普通 jquery 文件之后包含该文件。 所以到目前为止我所尝试的只是将脚本附加到 header ,同
您好,我尝试了广泛的谷歌搜索,但似乎没有任何帮助。 这是我的场景: 公司 Logo 存储在外部域/网址(矩形)中。 带有谷歌地图的 Ionic 应用程序,将这些 Logo 作为标记放置在 map 上。
我今天在阅读我的一些 C# 代码时发现了这一行: if (ProgenyList.ItemContainerGenerator.Status != System.Windows.Controls.Pr
我刚遇到this question在 Go FAQ 中,它让我想起了困扰我一段时间的事情。不幸的是,我真的不明白答案是什么。 似乎几乎所有非 C 类语言都将类型放在变量名之后,如下所示: var :
这是有效的 HTML 吗? 最佳答案 作为元素可以包含 phrasing content ,以及属于该组,则有效。 从语义上(并且具有一些常识),如果唯一的内容是 , 不;如果它同时包含文本和图像
这是有效的 HTML 吗? 最佳答案 作为元素可以包含 phrasing content ,以及属于该组,则有效。 从语义上(并且具有一些常识),如果唯一的内容是 , 不;如果它同时包含文本和图像
我有两本 T.Parr 写的关于 ANTLR 的书,我到处都看到美元符号和符号的引用。它也对我有用: term : IDENT -> { new TokenNode($IDENT) }; 或更复杂的东
我在实现段控制时遇到了一些问题。因为我希望它是一个固定的标题,所以当我滚动时我总是可以看到它,我已经在 - (UIView *)tableView:(UITableView *)tableView v
我有一个 20x36px (10x18pt) 的箭头图像,当我选择一个 UIImageView 时,将它拖到我的 View Controller 上然后设置图像,它总是模糊的。我只在我的项目中包含 @
How can I put background image when I hover a link Insert Bg in this a when hov
我需要在我的 .container 中添加(最新的第一个)新分区,但在 .controls (按钮)之后。可能吗? 注意:添加新的分区来保存按钮下方的前置控件对我来说不是一个选择。 HTML 需要保持
我是一名优秀的程序员,十分优秀!