- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在 React.js 上构建一个小型应用程序,并使用 D3 绘制与其接收到的 Prop 相对应的立方体。
class Visual extends React.Component {
renderD3 = (records, selector) => {
const data = records;
console.log('inside renderD3', data);
// It logs out most updated props every time it receives new props
const visual = this.props.connectFauxDOM('div', selector);
d3
.select(visual)
.attr('class', 'visual-wrapper')
.selectAll('div')
.data(data) // bind data
.enter()
.selectAll('div')
.data(d => d3.range(d.duration / 5).map(() => d))
.enter()
.append('div')
.attr('class', 'block')
.style('background-color', d => d.color);
}
componentDidMount() {
// it is just for generating gray grids for background setting, please ignore
this.renderD3([{duration: 300, color: '#e6e6e6'}], 'defaultBox')
}
render() {
this.renderD3(this.props.records, 'box')
return (
<div>
<div className="line-container">{this.props.defaultBox}</div>
<div className="line-container">{this.props.box}</div>
</div>
);
}
}
我想要实现的是,一旦visual
组件收到新的 Prop ,D3就会用新的颜色重新绘制(新的 Prop 有不同的颜色)。
到目前为止,在 renderD3 函数内,它接收新的 Prop ,并且在控制台上,它确实正确记录新 Prop ,但立方体仍然具有相同的颜色。问题是,如果我进行哈希刷新,则颜色会发生变化,就像 D3 中使用新 Prop 绘制立方体一样。
我想象过,一旦 Visual
组件每次收到新的 props 重新渲染,D3 立方体就会自动重绘(或更新)立方体。但在 renderD3 函数内部,它接收新的 props 并在每次重新渲染时记录新的 props,D3 立方体不会改变。
我对 React 相当熟悉,但对 D3 知之甚少。顺便说一下,我正在使用react-faux-dom将d3与react集成。
如果有任何见解,我将不胜感激。
提前谢谢您。
最佳答案
所以,据我所知,您正在使用 connectFauxDOM
工具,当您不需要动画时,该工具实际上是为动画保留的? (我可能是错的......)
文档存在一个已知问题,尚不清楚您是否需要使用此工具。您应该能够使用普通的无状态 API:
const ReactFauxDOM = require('react-faux-dom');
class Visual extends React.Component {
renderD3 = (data) => {
console.log('inside renderD3', data);
// It logs out most updated props every time it receives new props
const el = ReactFauxDOM.createElement('div');
d3.select(el)
.attr('class', 'visual-wrapper')
.selectAll('div')
.data(data) // bind data
.enter()
.selectAll('div')
.data(d => d3.range(d.duration / 5).map(() => d))
.enter()
.append('div')
.attr('class', 'block')
.style('background-color', d => d.color);
return el.toReact();
}
render() {
return (
<div>
<div className="line-container">{this.renderD3(this.props.records)}</div>
</div>
);
}
}
如果您打算使用动画,则需要 connectFauxDOM
。如果您不需要执行此类操作,那么正常的 createElement
和 toReact
流程应该更容易使用。我希望这有帮助!
关于reactjs - D3组件在收到新的props后不会重新绘制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49787696/
我仍在学习如何将 API 数据与 react 和 nextjs 一起使用。但是,为什么我的函数只在我编写 {props.props.title} 而不是我期望的 {props.title} 时起作用?
我仍在学习如何将 API 数据与 react 和 nextjs 一起使用。但是,为什么我的函数只在我编写 {props.props.title} 而不是我期望的 {props.title} 时起作用?
我正在用 TypeScript 构建一个 React 应用程序。我有一个 RequiresPermission基于谓词的组件应该渲染一个或另一个组件并转发所有 Prop 。 type Props =
我想通过 gatsby 布局传递我所有的 props。例如: import React, { Component } from 'react'; export default class Exampl
如果我使用合成属性,那我为什么不直接说: self.property = nil; 这将释放引用计数,并确保我没有悬挂指针。 看起来很简单,但我看到的 99% 的代码似乎都是这样做的: [proper
Eslint 抛出 eslint(react/prop-types) 错误,尽管已经声明了 propTypes。我正在使用 eslint-plugin-react 我研究了其他几个类似的问题以及 li
我正在使用以下由 linter eslint-plugin-react 解析的代码。它返回警告: "product is missing in props validation" 当我在底部的 pro
我正在尝试在 React 应用程序中添加 TypeScript。 版本: "react": "16.9.0", "typescript": "3.5.3", 我有一个像这样的数组 import aLo
我有一个组件 . 如果组件没有 this.props.children , 我想设置 Prop ariaLabel作为isRequired ,否则 in 可以是可选的。我该怎么做? ariaLabe
我应该用一个代替另一个吗?一起使用它们更好吗?谢谢。 最佳答案 prop in obj 检查 obj 是否有名为 prop 的属性,即使它只是从原型(prototype)继承而来。 obj.hasOw
我的组件 Text有 2 个 Prop :isHideable: boolean和 hidden: boolean .我如何允许 Hidden仅在 isHideable 时作为 Prop 是true
我试图将带有一些 Prop 的功能组件发送到另一个组件,并在接收组件中尝试键入检查该组件的某些 Prop 。这是代码: // BaseButton.tsx export type ButtonProp
是否可以从也作为 prop 传递的未知组件推断出正确的 props 类型? 如果已知组件(存在于当前文件中),我可以获得 Prop : type ButtonProps = React.Compone
我对 react 还很陌生,这是我正在努力解决的问题。 有一个父组件 家长 它将 Prop 传递给 child 。 其中一个 Prop ,包括一个要渲染的元素,如下所示: 在子组件中,我想获取这个组
我想做一个 Tabs推断 active 的可能值的组件prop 基于它的 child 拥有的东西 name Prop 。这就是我尝试这样做的方式: import React from 'react'
我对 react 还很陌生,并且只有当用户开始向下滚动时,我才尝试将更多信息加载到记录数组中。问题是新信息出现在数组中,但如果您尝试调用它,它将返回undefined。我在这里不明白什么? 父组件:
因此,如果我对一个组件有很多不同的 Prop ,我希望我可以做类似的事情 const { ...props } = props; 而不是 const { prop1, prop2, prop3, ..
这是我寻求指导的问题类型,因为我不确定我正在寻找的内容是否存在...... 上下文:我正在使用 Firestore 来保存数据,并且正在构建一个可重用的自定义 Hook (React 16.8),以便
我有一个 React 组件,它获取一个配置对象作为 prop,它看起来像这样: { active: true, foo: { bar: 'baz' } } 在
如何附加另一个属性?我有一个 react 组件,其中有人传入 ...props,我想附加一个额外的 Prop 最佳答案 请记住,传递 Prop 的顺序将决定将哪个值传递给该组件。这适用于有两个同名
我是一名优秀的程序员,十分优秀!