اذهب إلى المحتوى

السؤال

نشر

كيف يمكنني أن أقوم بتمرير قيمة لدالة يتم إستدعائها في onClick event في مكون React، حاولت إستخدام الكواد التالي:

var ClickableButton = React.createClass({
  handleClick:  function(value) {
    console.log(value);
  },
  
  render: function () {
    var that = this;
    return(
	<button onClick={that.handleClick} >Content</button>

    );
  }
});

لكن بدلًا من ذلك ظهر لي كائن من نوع SyntheticMouseEvent في الـ console بالشكل التالي:

SyntheticMouseEvent {dispatchConfig: Object, dispatchMarker: ".1.1.0.2.0.0:1", nativeEvent: MouseEvent, type: "click", target

كيف يمكنني تمرير قيمة إلى دالة handleClick حيث يمكنني طباعتها في الـ Console؟

Recommended Posts

  • 0
نشر

يمكنك استخدام arrow function في الجزء التالي لحل المشكلة.

handleClick = (item) => (e) => {
  e.preventDefault()    
  console.log(`This has access to item ${item}! and event(e)`)
}

.

return (
  <button onClick={() => this.handleClick(item)}> Content </button>
);

بهذه الحالة سيتم إنشاء دالة أخرى تقوم باستدعاء handleClick الخاص بك

  • 0
نشر

هناك طريقتين لتمرير الدالة لل onClick event :

الطريقة المعمول بها الان

هذه الطريقة عيبها أنها في كل حدث ضغط تقوم بانشاء دالة جديدة وهذا يسبب اعادة تشغيل للمكون غير ضرورية 

return (
  <button onClick={() => this.handleClick(value)}> Content </button>
);

الطريقة القديمة 

return (
  <button onClick={this.handleClick.bind(this,value)}> Content </button>
);

 

انضم إلى النقاش

يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.

زائر
أجب على هذا السؤال...

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   جرى استعادة المحتوى السابق..   امسح المحرر

×   You cannot paste images directly. Upload or insert images from URL.

  • إعلانات

  • تابعنا على



×
×
  • أضف...