首頁 > web前端 > js教程 > 在ES6中子元件怎麼呼叫父元件

在ES6中子元件怎麼呼叫父元件

php中世界最好的语言
發布: 2018-03-17 14:37:47
原創
1423 人瀏覽過

這次帶給大家在ES6中子元件怎麼呼叫父元件,在ES6中子元件呼叫父元件的注意事項有哪些,下面就是實戰案例,一起來看一下。

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

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

因為我看的影片是基於es5的語法來實現的程式碼,所以語法有些不同。

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

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

#或是在子元件綁定的時候就寫this.xxxxx.bind(this ) .

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

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={&#39;pink&#39;} onPress={this.timesReset.bind(this)}>

        <Text style={{textAlign:&#39;center&#39;}}>爹,再给你儿子一次机会!!</Text>

      </TouchableHighlight>

    </View>

    );

  }

}

登入後複製

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

JS常用的訊息方塊有哪些

js隨機產生6位元隨機數字

js動態建立標籤以及設定屬性的方法

#

以上是在ES6中子元件怎麼呼叫父元件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板