国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

ES6下子組件調用父組件的方法(推薦)

2024-05-06 16:42:35
字體:
來源:轉載
供稿:網友

出于某些目的,最近又開始研究起了RN,看著教程一步步的學習,在最近卻是碰到了一個問題,那就是父子組件的方法調用的問題。

這個問題我百度了很久,JS的ES6語法下,用class創建組件,子組件調用父組件方法模擬器不斷報錯。

因為我看的視頻是基于es5的語法來實現的代碼,所以語法有些不同。

es5的語法下,方法的this都是RN已經幫我們處理好了的,所以按照視頻中的示例是可以達成效果的,但是es6貌似是要自己寫的。。

具體的寫法就是在constructor中添加 this.xxxxx = this.xxxxx.bind(this);

或者在子組件綁定的時候就寫this.xxxxx.bind(this) .

這里就不多講了,下面上代碼,以供需要的人參考。

export default class TestPrj extends Component {    constructor(props){      super(props);      this.timesReset = this.timesReset.bind(this);      this.state = {timex:2};    }    timesReset(){      this.setState({        timex:0      });    }    render() {      return(        <View style={styles.container}>          <Son ref="Son1" timex={this.state.timex} timesReset={this.timesReset}/>          //或者<Son ref="Son1" timex={this.state.timex} timesReset={this.timesReset.bind(this)}/>        </View>      );    }  } class Son extends Component{    constructor(props){    super(props);    this.state = {times:this.props.timex};  }  componentWillReceiveProps(props){    console.log(this.props);    this.setState({      times:props.timex    })  }  timesReset(){    this.props.timesReset();  }  render(){    return(    <View style={styles.container}>      <Text style={styles.instructions}>      兒子:雖然你揍了我 {this.state.times} 次,但是我 永 不 屈 服!!      </Text>      <TouchableHighlight style={styles.btn} underlayColor={'pink'} onPress={this.timesReset.bind(this)}>        <Text style={{textAlign:'center'}}>爹,再給你兒子一次機會!!</Text>      </TouchableHighlight>    </View>    );  }}

以上這篇ES6下子組件調用父組件的方法(推薦)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 佳木斯市| 龙门县| 阜阳市| 连山| 澄迈县| 绿春县| 东宁县| 永定县| 房产| 邵武市| 革吉县| 霍林郭勒市| 江门市| 额尔古纳市| 大余县| 宁南县| 白银市| 庄浪县| 安义县| 昌乐县| 安国市| 冕宁县| 柘荣县| 沾益县| 尼木县| 东方市| 宁城县| 南岸区| 三亚市| 自贡市| 马鞍山市| 西畴县| 射洪县| 毕节市| 怀柔区| 深水埗区| 重庆市| 迁安市| 成武县| 同心县| 额尔古纳市|