gpt4 book ai didi

javascript - 为什么这个注释在 Javascript/React 代码中作为参数传递?

转载 作者:行者123 更新时间:2023-11-30 07:51:31 27 4
gpt4 key购买 nike

我正在处理 this React Tutorial更具体地说,使用下面这个 Code Pen 中的简单代码.

我在结束标记的其中一行中添加了注释(HERE IS THE COMMENT),如您所见:

<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.min.js"></script>
class Square extends React.Component {
constructor(props) {
super(props);
this.state = {
value: null,
};
}

render() {
return (
<button
className="square"
onClick={() => this.setState({value: 'X'})}
> // HERE IS THE COMMENT
{this.state.value}
</button>
);
}
}

class Board extends React.Component {
renderSquare(i) {
return <Square />;
}

render() {
const status = 'Next player: X';

return (
<div>
<div className="status">{status}</div>
<div className="board-row">
{this.renderSquare(0)}
{this.renderSquare(1)}
{this.renderSquare(2)}
</div>
<div className="board-row">
{this.renderSquare(3)}
{this.renderSquare(4)}
{this.renderSquare(5)}
</div>
<div className="board-row">
{this.renderSquare(6)}
{this.renderSquare(7)}
{this.renderSquare(8)}
</div>
</div>
);
}
}

class Game extends React.Component {
render() {
return (
<div className="game">
<div className="game-board">
<Board />
</div>
<div className="game-info">
<div>{/* status */}</div>
<ol>{/* TODO */}</ol>
</div>
</div>
);
}
}

// ========================================

ReactDOM.render(
<Game />,
document.getElementById('root')
);

事实证明,这个注释 实际上修改了传递给 Square 组件的参数。如果没有注释,代码会呈现一个 3x3 的网格,里面什么也没有,但是有了注释,注释中的任何内容都会呈现在方 block 中(在本例中,“HERE IS THE COMMENT”)

这是为什么?

最佳答案

那不是 jsx 注释,但尝试将 //HERE IS THE COMMENT 变成真正的 React 注释

{/* 评论 */>

关于javascript - 为什么这个注释在 Javascript/React 代码中作为参数传递?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52141419/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com