Answers:
React(或JSX)不支持在属性值内进行变量插值,但是您可以将任何JS表达式放在花括号内作为整个属性值,因此可以这样做:
<img className="image" src={"images/" + this.props.image} />
如果要使用es6模板文字,则还需要在刻度线周围加上大括号:
<img className="image" src={`images/${this.props.image}`} />
对于People,寻找“映射”功能和动态数据的答案,这是一个有效的示例。
<img src={"http://examole.com/randomview/images" + each_actor['logo']} />
这样,URL为“ http://examole.com/randomview/images/2/dp_pics/182328.jpg ”(随机示例)
注意:在react中,您可以将javascript表达式放在大括号内。在此示例中,我们可以使用此属性。
注意:请看以下示例:
class LoginForm extends React.Component {
constructor(props) {
super(props);
this.state = {i:1};
}
handleClick() {
this.setState(prevState => ({i : prevState.i + 1}));
console.log(this.state.j);
}
render() {
return (
<div>
<p onClick={this.handleClick.bind(this)}>Click to change image</p>
<img src={'images/back'+ this.state.i+'.jpg'}/>
</div>
);
}
}
这是动态className或Props的最佳选择,就像我们在Javascript中一样进行一些串联。
className={
"badge " +
(this.props.value ? "badge-primary " : "badge-danger ") +
" m-4"
}
classnames
用于构建动态className的包
您可以使用
<img className="image" src=`images/${this.props.image}`>
要么
<img className="image" src={'images/'+this.props.image}>
要么
render() {
let imageUrl = this.props.image ? "images/"+this.props.image : 'some placeholder url image';
return (
<div>
<img className="image" src={imageUrl} />
</div>
)
}