如果我在react组件中创建了一个变量,如何在状态改变时重新访问它?
If I make a variable inside a react component, how do I re-access it on a state change?
我正在制作一个react项目,并使用wavesurfer.js。当我点击播放按钮时,我将道具播放从false更改为true,用于使元素实际播放的方法是visual.playPause();然而,我不确定我如何得到一个引用回到变量后,我创建了它(变量是可视化的,这是在initWaveSurfer函数中创建的)。任何帮助都会很棒!!
var React = require('react');
var ReactDom = require('react-dom');
var reactWaveSurfer = React.createClass({
getInitialState: function(){
return ({
song: this.props.song,
playing: this.props.playing
});
},
componentDidMount: function () {
this.initWavesurfer();
},
componentWillReceiveProps: function(nextProps) {
this.setState({
playing: nextProps.playing
});
},
initWavesurfer: function () {
var visualContainer = ReactDom.findDOMNode(this.refs.waveContainer);
var visual = WaveSurfer.create({
container: visualContainer,
waveColor: 'blue',
progressColor: 'purple',
barWidth: '3',
height: "90",
maxCanvasWidth: 200
});
visual.load(this.state.song.audio_url);
},
render: function () {
return <div className="wave-surfer" ref="waveContainer" ></div>;
}
});
module.exports = reactWaveSurfer;
您可以通过从this.initWavesurfer
返回它并从中设置状态来访问它。从那里,您可以通过this.state.visual
;
var React = require('react');
var ReactDom = require('react-dom');
var reactWaveSurfer = React.createClass({
getInitialState: function(){
return ({
song: this.props.song,
playing: this.props.playing
});
},
componentDidMount: function () {
this.setState({visual: this.initWavesurfer()}); //You now have access to visual thru this.state.visual
},
componentWillReceiveProps: function(nextProps) {
this.setState({
playing: nextProps.playing
});
},
initWavesurfer: function () {
var visualContainer = ReactDom.findDOMNode(this.refs.waveContainer);
var visual = WaveSurfer.create({
container: visualContainer,
waveColor: 'blue',
progressColor: 'purple',
barWidth: '3',
height: "90",
maxCanvasWidth: 200
});
visual.load(this.state.song.audio_url);
return visual;
},
render: function () {
return <div className="wave-surfer" ref="waveContainer" ></div>;
}
});
module.exports = reactWaveSurfer;
你应该能够使用this.state.[variable]访问状态变量。在你的例子中this。state。playing和this。state。song
在React.js
组件中,this.state.<state name>
可以从自身内部访问所有当前state
值。
相关文章:
- 表示改变状态的函数的Redux字
- 当道具函数改变状态时,我该如何使用redux
- ReactJS:如何在改变状态后立即更新组件
- 在不改变状态的情况下,根据减少器中的给定索引更改嵌套数组值
- React-道具改变时改变状态
- 在材质设计和angularjs中不动态改变状态的复选框
- React不会立即改变状态
- react.js在改变状态数组后不更新DOM
- 改变状态时URL不更新
- ui.路由器改变状态,但ui-view不显示任何东西
- 如何改变状态的所有复选框(在所有页面),当点击selectAll复选框[使用jQuery数据表]
- ui -路由器在使用$state.go()时不改变状态
- componentDidMount中的setState不会改变状态
- AJAX调用不工作在React一旦我改变状态
- 如何在angular js中应用加载器/旋转器来改变状态
- 背面的离子嵌套状态不会改变状态
- Vuex在分派动作时改变状态中的2个元素
- 不能用Cordova改变状态栏
- 为什么点击一个改变状态且与ajax调用无关的选项卡会创建ajax调用?
- CSS活动伪类改变状态吞噬onclick事件