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

السؤال

نشر

لدي مكون React التالي:

import React from 'react'

class Content extends React.Component {
  constructor(props) {
    super(props)
    this.state = {content: ''}
  }

  changeContent(e) {
    this.setState({content: e.target.value})
  } 

  render() {
    return (
      <div>
        Title: 
        <input type="text" value={this.content} 
          onChange={this.changeContent} />
      </div>
    )
  }
}

export default Content

لكن عند الكتابة في يظهر لي الخطأ:

this.setState is not a function

 

Recommended Posts

  • 0
نشر

يجب عليك عمل bind مثلما قال الأخ عبدالله

لكن إذا كان الأمر ليس واضحاً لك وأيضاً تريد إختصار الكود وجعله أسهل يمكنك استخدام دالة السهم arrow function لكي تتجنب استخدام bind

يمكنك تغيير الكود السابق الى هذا الشكل

import React from 'react'

class Content extends React.Component {
  constructor(props) {
    super(props)
    this.state = {content: ''}
  }

  changeContent = (e)=> {						// دالة السهم
    this.setState({content: e.target.value})	//Arrow Function
  } 

  render() {
    return (
      <div>
        Title: 
        <input type="text" value={this.content} 
          onChange={this.changeContent} />
      </div>
    )
  }
}

export default Content

 

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

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

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

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   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.

  • إعلانات

  • تابعنا على



×
×
  • أضف...