We want to hear from you!Take our 2020 Community Survey!

Handling Events

<<<<<<< HEAD React கூறுகளுடன் நிகழ்வுகளைக் கையாளுதல் DOM கூறுகளுடன் நிகழ்வுகளைக் கையாளுவதற்கு மிகவும் ஒத்திருக்கிறது. சில தொடரியல் வேறுபாடுகள் உள்ளன: ======= Handling events with React elements is very similar to handling events on DOM elements. There are some syntax differences:

bd0c9d8c5f5e78e0bd1066b46024ba98f4daac84

  • சிறிய எழுத்துக்களைக் காட்டிலும், ஒட்டக வடிவ எழுத்துக்களைக் பயன்படுத்தி React நிகழ்வுகள் பெயரிடப்பட்டுள்ளன.
  • JSX உடன் நீங்கள் ஒரு செயக்கூற்றை விட, செயற்பாடு கையாளுபவராக ஒரு செயல்பாட்டை அனுப்புகிறீர்கள், சொல்லுக்கு மாறாக.

உதாரணத்திற்கு, இந்த HTML:

<button onclick="activateLasers()">
  Activate Lasers
</button>

React-ல் சற்று வித்தியாசமானது:

<button onClick={activateLasers}>  Activate Lasers
</button>

மற்றொரு வித்தியாசம் என்னவென்றால், React-ல் இயல்புநிலை நடத்தையைத் தடுக்க நீங்கள் falseயை தர முடியாது. நீங்கள் preventDefault வெளிப்படையாக அழைக்க வேண்டும். உதாரணத்திற்கு, தெளிவாக HTML உடன், புதிய பக்கத்தைத் திறக்கும் இயல்புநிலை இணைப்பு நடத்தையை தடுக்க, நீங்கள் எழுதலாம்:

<a href="#" onclick="console.log('The link was clicked.'); return false">
  Click me
</a>

React-ல் இதற்கு பதிலாக:

function ActionLink() {
  function handleClick(e) {    e.preventDefault();    console.log('The link was clicked.');  }
  return (
    <a href="#" onClick={handleClick}>      Click me
    </a>
  );
}

<<<<<<< HEAD இங்கே, e ஒரு செயற்கை நிகழ்வு. React இந்த செயற்கை நிகழ்வுகளை W3C விவரம் விவரக்குறிப்பின் படி வரையறுக்கிறது, எனவே குறுக்கு-உலாவி பொருந்தக்கூடிய தன்மையைப் பற்றி நீங்கள் கவலைப்பட தேவையில்லை. மேலும் அறிய, செயற்கைநிகழ்வு குறிப்பு வழிகாட்டியைப் பார்க்கவும். ======= Here, e is a synthetic event. React defines these synthetic events according to the W3C spec, so you don’t need to worry about cross-browser compatibility. React events do not work exactly the same as native events. See the SyntheticEvent reference guide to learn more.

bd0c9d8c5f5e78e0bd1066b46024ba98f4daac84

React-ஐ பயன்படுத்தும் போது, ​​பொதுவாக ஒரு DOM கூறு உருவாக்கப்பட்ட பிறகு கவனிப்பவர்களைச் சேர்க்க addEventListener-ஐ அழைக்க தேவையில்லை. அதற்கு பதிலாக, கூறு ஆரம்பத்தில் காண்பிக்கப்படும் போது கவனிப்பவருக்கு வழங்கவும்.

ES6 வகுப்பைப் பயன்படுத்தி ஒரு கூறுகளை நீங்கள் வரையறுக்கும்போது, ஒரு பொதுவான மாதிரி நிகழ்வு கையாளுபவர் வகுப்பில் ஒரு முறையாக இருப்பது. உதாரணத்திற்கு, இந்த Toggle கூறு ஒரு பொத்தானை அளிக்கிறது, இது பயனரை “ஆன்” மற்றும் “ஆஃப்” இடையே மாற்ற அனுமதிக்கிறது:

class Toggle extends React.Component {
  constructor(props) {
    super(props);
    this.state = {isToggleOn: true};

    // This binding is necessary to make `this` work in the callback    this.handleClick = this.handleClick.bind(this);  }

  handleClick() {    this.setState(state => ({      isToggleOn: !state.isToggleOn    }));  }
  render() {
    return (
      <button onClick={this.handleClick}>        {this.state.isToggleOn ? 'ON' : 'OFF'}
      </button>
    );
  }
}

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

CodePen-ல் முயற்சி செய்க

JSX கால்பேக்குகளில் இதன் பொருள் குறித்து நீங்கள் கவனமாக இருக்க வேண்டும். Javascript-ல், வகுப்பு முறைகள் இயல்பாகவே பிணைக்க-ப்படவில்லை. this.handleClick-ஐ பிணைக்க மற்றும் onClick-ஐ அனுப்ப மறந்தால், செயற்பாடு உண்மையில் அழைக்கப்படும் போது this என்பது undefined-ஆக இருக்கும்.

இது React சார்ந்த நடத்தை அல்ல; இது JavaScript-ல் செயல்பாடுகள் எவ்வாறு செயல்படுகின்றன. என்பதின் ஒரு பகுதியாகும். பொதுவாக, () இல்லாமல் ஒரு முறையை நீங்கள் குறிப்பிட்டால், onClick={this.handleClick} போன்று, நீங்கள் அந்த முறையை பிணைக்க வேண்டும்.

bind-பை அழைப்பது எரிச்சலூட்டினால், இதைச் சுற்றி உங்களுக்கு இரண்டு வழிகள் உள்ளன. நீங்கள் சோதனையைப் பயன்படுத்துகிறீர்கள் என்றால் பொது வகுப்பு புலங்கள் தொடரியல், கால்பேக்குகளை சரியாக பிணைக்க நீங்கள் வகுப்பு புலங்களைப் பயன்படுத்தலாம்:

class LoggingButton extends React.Component {
  // This syntax ensures `this` is bound within handleClick.  // Warning: this is *experimental* syntax.  handleClick = () => {    console.log('this is:', this);  }
  render() {
    return (
      <button onClick={this.handleClick}>
        Click me
      </button>
    );
  }
}

Create React App-ல் இந்த தொடரியல் இயல்பாகவே இயக்கப்பட்டது.

நீங்கள் வகுப்பு புலங்களின் தொடரியல் பயன்படுத்தவில்லை என்றால், கால்பேக்கில் நீங்கள் ஒரு அம்பு செயல்பாட்டைப் பயன்படுத்தலாம்:

class LoggingButton extends React.Component {
  handleClick() {
    console.log('this is:', this);
  }

  render() {
    // This syntax ensures `this` is bound within handleClick    return (      <button onClick={() => this.handleClick()}>        Click me
      </button>
    );
  }
}

இந்த தொடரியல் சிக்கல் என்னவென்றால், ஒவ்வொரு முறையும் LoggingButton வழங்கும்போது வேறுபட்ட அழைப்பு உருவாக்கப்படுகிறது. பெரும்பாலான சந்தர்ப்பங்களில், இது நன்று. எனினும், இந்த அழைப்பு குறைந்த கூறுகளுக்கு ஒரு ஆதாரமாக அனுப்பப்பட்டால், அந்த கூறுகள் கூடுதல் மறு-ஒழுங்கமைப்பைச் செய்யலாம். இந்த வகையான செயல்திறன் சிக்கலைத் தவிர்ப்பதற்கு, கட்டமைப்பாளரில் பிணைக்க அல்லது வர்க்க புலங்களின் தொடரியல் பயன்படுத்த பரிந்துரைக்கிறோம்.

நிகழ்வு கையாளுவதற்கு வாதங்களை அனுப்புதல்

ஒரு சுழற்சியின் உள்ளே ஒரு நிகழ்வு அளவுருவுக்கு கூடுதல் அளவுருவை அனுப்ப விரும்புவது பொதுவானது. உதாரணத்திற்கு, வரிசை ID id என்றால், பின்வருவனவற்றில் ஒன்று செயல்படும்:

<button onClick={(e) => this.deleteRow(id, e)}>Delete Row</button>
<button onClick={this.deleteRow.bind(this, id)}>Delete Row</button>

மேலே உள்ள இரண்டு வரிகள் சமமானவை, மற்றும் முறையே arrow functions மற்றும் Function.prototype.bind-ஐப் பயன்படுத்தவும்.

இரண்டு நிகழ்வுகளிலும், React நிகழ்வைக் குறிக்கும் e வாதம் ID-க்குப் பிறகு இரண்டாவது வாதமாக அனுப்பப்படும். அம்பு செயல்பாட்டுடன் நாம் அதை வெளிப்படையாக அனுப்ப வேண்டும், ஆனால் பிணைப்பு-டன் மேலும் வாதங்கள் தானாகவே அனுப்பப்படும்.

Is this page useful?Edit this page