- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我刚刚更新到 React Native 0.54.0,它还包括 React 16.3 的 alpha 1,自然地我收到了很多关于 componentWillMount
和 componentWillReceiveProps
贬值的警告。
我有一个动画路由组件,其核心依赖于 componentWillReceiveProps
它接收新路径,将其与之前的路径进行比较,如果它们是设置旧的子项,则将它们动画化,设置新的子项并将它们动画化。
这里是有问题的代码:
componentWillReceiveProps(nextProps: Props) {
if (nextProps.pathname !== this.props.pathname) {
this.setState({ previousChildren: this.props.children, pointerEvents: false }, () =>
this.animate(0)
);
}
}
现在回答我关于将其移植到 static getDerivedStateFromProps
1) 我不再有权访问 this.props
,因此无法访问以前的路径名,我想我可以将这些 Prop 存储在状态中,现在这是正确的方法吗?好像数据重复了。
2) 由于我无权访问 this
我无法调用依赖于状态的动画函数。我怎样才能绕过这个?
3) 我需要先设置状态然后调用动画,因为 getDerivedStateFromProps
通过返回值设置状态,之后我不能做太多,所以有没有办法设置状态和完成后执行回调?
4) pathname
位现在只在 componentWillreceiveProps
中使用,如果我将它移动到 state 并且从不在 this.state
中使用 getDerivedStateFromProps
(因为我不能) this.state.pathname
错误被定义但从未使用过。这里最好的方法也是让它成为静态的吗?
我的第一直觉是将其更改为 componentDidUpdate
,但我们不应该在其中使用 setState
对吗? (尽管这在我的场景中确实有效)。
componentDidUpdate(prevProps: Props) {
if (this.props.pathname !== prevProps.pathname) {
this.setState({ previousChildren: prevProps.children, pointerEvents: false }, () =>
this.animate(0)
);
}
}
注意: 据我所知,我认为“suspense”中有一项功能允许我们在组件卸载事件时保持 View 挂载?我找不到对此的任何引用,但这听起来像是我可以用于此动画的东西
对于任何感兴趣的人,这是一个完整组件的片段
// @flow
import React, { Component, type Node } from "react";
import { Animated } from "react-native";
type Props = {
pathname: string,
children: Node
};
type State = {
animation: Animated.Value,
previousChildren: Node,
pointerEvents: boolean
};
class OnboardingRouteAnomation extends Component<Props, State> {
state = {
animation: new Animated.Value(1),
previousChildren: null,
pointerEvents: true
};
componentWillReceiveProps(nextProps: Props) {
if (nextProps.pathname !== this.props.pathname) {
this.setState({ previousChildren: this.props.children, pointerEvents: false }, () =>
this.animate(0)
);
}
}
animate = (value: 0 | 1) => {
Animated.timing(this.state.animation, {
toValue: value,
duration: 150
}).start(() => this.animationLogic(value));
};
animationLogic = (value: 0 | 1) => {
if (value === 0) {
this.setState({ previousChildren: null, pointerEvents: true }, () => this.animate(1));
}
};
render() {
const { animation, previousChildren, pointerEvents } = this.state;
const { children } = this.props;
return (
<Animated.View
pointerEvents={pointerEvents ? "auto" : "none"}
style={{
alignItems: "center",
opacity: animation.interpolate({ inputRange: [0, 1], outputRange: [0, 1] }),
transform: [
{
scale: animation.interpolate({ inputRange: [0, 1], outputRange: [0.94, 1] })
}
]
}}
>
{previousChildren || children}
</Animated.View>
);
}
}
export default OnboardingRouteAnomation;
最佳答案
对于 React 版本 16.3,使用 componentWillReceiveProps
没问题,但会导致在控制台中显示弃用警告。 It will be removed in version 17 . FWIW Dan Abramov has warned against using alpha functionality in production - 但这是在 2018 年 3 月。
让我们来看看你的问题:
1) I no longer have access to this.props, hence no access to previous pathname, I guess I can store these props in state. Is this the correct approach now? Seems like repetition of data.
是的。
如果你想更新/重新渲染你的组件,你应该结合props
和state
。在您的情况下,您希望在使用生命周期方法更改 pathname
时更新组件/触发器动画。
Seems like repetition of data.
检查一下:React Team post on State and Lifecycle
2) As I have no access to this I can't call my animation function, which relies on state. How can I bypass this?
componentDidUpdate
This function will be called after render is finished in each of the re-render cycles. This means that you can be sure that the component and all its sub-components have properly rendered itself.
这意味着您可以在 componentDidUpdate
中的 setState
之后调用 animate
3) I need to first set state and then call the animation, as getDerivedStateFromProps sets state by returning the values, I can't do much afterwards, so is there a way to set state and after thats done execute a callback?
请参阅第 2 点(Use componentDidUpdate)
4) pathname bit is only used in componentWillreceiveProps right now, if I move it to state and never use this.state inside getDerivedStateFromProps (because I can't) this.state.pathname errors as being defined but never used. Is the best approach here to make it static as well?
不,它会被componentDidUpdate使用
以下是我的处理方法:
// @flow
import React, { Component, type Node } from "react";
type Props = {
pathname: string,
children: Node
};
type State = {
previousChildren: Node,
pointerEvents: boolean
};
class OnboardingRouteAnomation extends Component<Props, State> {
state = {
previousChildren: null,
pointerEvents: true,
pathname: ''
};
static getDerivedStateFromProps(nextProps, prevState) {
if (nextProps.pathname !== prevState.pathname) {
return {
previousChildren: nextProps.children,
pointerEvents: false,
pathname: nextProps.pathname
};
}
return null;
}
componentDidUpdate(prevProps, prevState) {
if (prevState.pathname !== this.state.pathname){
console.log("prevState.pathname", prevState.pathname);
console.log("this.props.pathname", this.props.pathname);
this.animate(0);
}
}
componentDidMount(){
this.setState({ pathname: this.props.pathname});
}
animate = (value: 0 | 1) => {
console.log("this animate called", this);
animationLogic(value);
};
animationLogic = (value: 0 | 1) => {
if (value === 0) {
this.setState({ previousChildren: null, pointerEvents: true }, () => this.animate(1));
}
};
render() {
const { animation, previousChildren, pointerEvents } = this.state;
const { children } = this.props;
return (
<div>
{this.props.children}
</div>
);
}
}
export default OnboardingRouteAnomation;
我相信这就是 React 开发人员希望处理的方式。你应该 在通过 componentDidUpdate
更新后调用 animate,因为这是一个副作用。
我会使用更具描述性的名称来指示路径已更改。类似于 isPathUpdated
。然后,您可以让 animate
检查 isPathUpdated
作为切换。
关于javascript - 需要以前的 Prop 和状态回调的静态 getDerivedStateFromProps?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49156717/
我正在通读 Windows Phone 7.5 Unleashed,有很多代码看起来像这样(在页面的代码隐藏中): bool loaded; protected override void OnNav
在cgi服务器中,我这样返回 print ('Status: 201 Created') print ('Content-Type: text/html') print ('Location: htt
我正在查看 esh(easy shell)的实现,无法理解在这种情况下什么是 22 和 9 信号。理想情况下,有一个更具描述性的常量,但我找不到列表。 最佳答案 信号列表及其编号(包括您看到的这两个)
我的Oozie Hive Action 永远处于运行模式。 oozie.log文件中没有显示错误。
我正在编写一个使用 RFCOMM 通过蓝牙连接到设备的 Android 应用程序。我使用 BluetoothChat 示例作为建立连接的基础,大部分时间一切正常。 但是,有时由于出现套接字已打开的消息
我有一个云调度程序作业,它应该每小时访问我的 API 以更新一些价格。这些作业大约需要 80 秒才能运行。 这是它的作用: POST https://www.example.com/api/jobs/
我正在 Tomcat 上访问一个简单的 JSP 页面: 但是当我使用 curl 测试此页面时,我得到了 200 响应代码而不是预期的 202: $ curl -i "http://localhos
有时 JAR-RS 客户端会发送错误的语法请求正文。服务器应响应 HTTP status 400 (Bad Request) , 但它以 HTTP status 500 (Internal Serve
我正在尝试通过 response.send() 发送一个整数,但我不断收到此错误 express deprecated res.send(status): Use res.sendStatus(sta
我已经用 Excel 和 Java 做过很多次了……这次我需要用 Stata 来做,因为保存变量更方便'labels .如何将 dataset_1 重组为下面的 dataset_2? 我需要转换以下
我正在创建一个应用程序,其中的对象具有状态查找功能。为了提供一些上下文,让我们使用以下示例。 帮助台应用程序,其中创建作业并通过以下工作流程移动: 新 - 工作已创建但未分配 进行中 - 分配给工作人
我想在 Keras 中运行 LSTM 并获得输出和状态。在 TF 中有这样的事情 with tf.variable_scope("RNN"): for time_step in range
有谁知道 Scala-GWT 的当前状态 项目? 那里的主要作者 Grzegorz Kossakowski 似乎退出了这个项目,在 Spring 中从事 scalac 的工作。 但是,在 interv
我正在尝试编写一个 super 简单的 applescript 来启动 OneDrive App , 或确保打开,当机器的电源设置为插入时,将退出,或确保关闭,当电源设置为电池时。 我无法找到如何访问
目前我正在做这样的事情 link.on('click', function () { if (link.attr('href') !== $route.current.originalPath
是否可以仅通过查看用户代理来检测浏览器上是否启用/禁用 Javascript。 如果是,我应该寻找什么。如果否,检测用户浏览器是否启用/禁用 JavaScript 的最佳方法是什么 最佳答案 不,没有
Spring 和 OSGi 目前的开发状况如何? 最近好像有点安静了。 文档的最新版本 ( http://docs.spring.io/osgi/ ) 来自 2009 年。 我看到一些声明 Sprin
我正在从主函数为此类创建一个线程,但即使使用 Thread.currentThread().interrupt() 中断它,输出仍然包含“Still Here”行。 public class Writ
为了满足并发要求,我想知道如何在 Godog 中的多个步骤之间传递参数或状态。 func FeatureContext(s *godog.Suite) { // This step is ca
我有一个UIButton子类,它不使用UIImage背景,仅使用背景色。我注意到的一件事是,当您设置按钮的背景图像时,有一个默认的突出显示状态,当按下按钮时,该按钮会稍微变暗。 这是我当前的代码。
我是一名优秀的程序员,十分优秀!