Как получить массив ссылок

Привет ребята!

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>
    </>
  }
}
Другие вопросы по тегам