Как получить массив ссылок
Привет ребята!
export default class Test extends React.Component {
constructor(props) {
super(props);
this.ref = [];
}
handleClick = () => {
let doc;
doc = this.refs["link" + 0];
console.log("ref is => " + doc.innerHTML);
}
render() {
return (
<div>
<p ref={"link" + 0} onClick={this.handleClick}> p1</p>
<p ref={"link" + 1} onClick={this.handleClick}> p2</p>
</div>
);
}
}
Как я могу узнать, по какой ссылке я щелкнул, когда вхожу в функцию handleClick? Спасибо за помощь!
2 ответа
Решение
export default class Test extends React.Component {
handleClick = (linkRef) => {
console.log("ref is => " + this.refs[linkRef].innerHTML);
}
render() {
return (
<div>
<p ref='linkOne' onClick={() => this.handleClick('linkOne')}> p1</p>
<p ref='linkTwo' onClick={() => this.handleClick('linkTwo')}> p2</p>
</div>
);
}
}
Это может быть полезно для вас
class App extends React.Component {
constructor() {
super();
this.domRefs = []
}
handleClick() {
console.log(this.domRefs);
}
render() {
return <>
<div onClick={this.handleClick.bind(this)} >
<ul>
<li ref={r => this.domRefs.push(r)} >1</li>
<li ref={r => this.domRefs.push(r)} >2</li>
<li ref={r => this.domRefs.push(r)} >3</li>
<li ref={r => this.domRefs.push(r)} >4</li>
<li ref={r => this.domRefs.push(r)} >5</li>
</ul>
</div>
</>
}
}