Dr.*_*man 7 javascript this reactjs
此代码适用于Codepen:请参阅https://codepen.io/pkshreeman/pen/YQNPKB?editors=0010 但是我试图在我自己的'create-react-app'中使用它,并且错误为'不受限制 -全局'被触发event.target.id.什么是解决方法.除了使用事件目标之外,你如何从'this'得到id?
const Elem = (props) =>{
return (<div>
<h1 onClick={props.clickon} id="GM"> Good Morning!
<br/>
{props.name} {props.last}
<br />
This is phase three</h1>
<button id="btn1" onClick={props.clickon}> {props.text} </button>
<button id="btn2" onClick={props.clickon}> Second Button </button>
</div>
);
};
class App extends React.Component{
constructor(props) {
super(props);
this.handleClick = this.handleClick.bind(this);
}
handleClick(){
var clickedId = event.target.id;
console.log(clickedId);
alert("It works! You clicked " + clickedId)
}
render(){
return (
<Elem name = 'paul' last='shreeman' clickon={this.handleClick} text='PushMe'/>
)
}
}
ReactDOM.render(
<App />, document.getElementById('root'))
Run Code Online (Sandbox Code Playgroud)
奇怪的是,这甚至可以在codepen中运行 - 看起来你正在使用全局event属性.
正确的方法是从handleClick函数的第一个参数中获取事件对象:
handleClick(event) {
var clickedId = event.target.id;
console.log(clickedId);
alert("It works! You clicked " + clickedId)
}
Run Code Online (Sandbox Code Playgroud)
我猜您可能需要在传递函数上指定事件。
const Elem = (props) =>{
return (<div>
<h1 onClick={props.clickon} id="GM"> Good Morning!
<br/>
{props.name} {props.last}
<br />
This is phase three</h1>
<button id="btn1" onClick={props.clickon}> {props.text} </button>
<button id="btn2" onClick={props.clickon}> Second Button </button>
</div>
);
};
class App extends React.Component{
constructor(props) {
super(props);
this.handleClick = this.handleClick.bind(this);
}
handleClick(event){
var clickedId = event.target.id;
console.log(clickedId);
alert("It works! You clicked " + clickedId)
}
render(){
return (
<Elem name = 'paul' last='shreeman' clickon={(event)=>this.handleClick(event)} text='PushMe'/>
)
}
}
ReactDOM.render(
<App />, document.getElementById('root'))
Run Code Online (Sandbox Code Playgroud)
如果它适合你,请尝试一下。
| 归档时间: |
|
| 查看次数: |
14346 次 |
| 最近记录: |