亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

FLutter組件通信(1)

標簽:
Android iOS

本文介绍flutter父子组件数据传递和回调.

还是以之前的代码为例Flutter_DayByDay由于之前用React-Native写项目,顺便对比一下

RN

父组件直接在xml标签中写属性={值/方法},子组件通过props去取属性和方法


父组件类中

<MenuItem title={'新手指引'} img={'新手指引'} click = {() => {

}}/>

子组件类

<Image

                    style={styles.image}

                    source={{uri:this.props.img}}

                    resizeMode={'center'}

                />

<TouchableOpacity onPress={this.props.onPressFirst} >
Flutter

这里将之前RaisedButton组件再做一次抽取


//子组件

import 'package:flutter/material.dart';

class ProductControl extends StatelessWidget {

   // 声明一个方法成员方法 

    final Function addProduct;

  //保存传递来方法(引用)

  ProductControl(this.addProduct);

  @override

    Widget build(BuildContext context) {

      // TODO: implement build

      return RaisedButton(

          child: Text("add Product"),

          onPressed: (){

            //通过这个方法引用找到回调方法调用

            addProduct('hhh');

          },

        );

    }

}

//父组件

//回调函数

  void _addProduct(String product) {

    //通知刷新

    setState(() {

      _products.add(product);

      print(product);

    });

  }

  @override

  Widget build(BuildContext context) {

    print('[ProductsManager State] build');

    return (Column(children: [

      Container(

        padding: EdgeInsets.all(10.0),

        //传递回调函数(引用)给子组件

        child: ProductControl(_addProduct),

      ),

      Products(_products)

    ]));

  }

两者设计思路类似,flutter的更加接近面向对象语法,变量或函数作为函数参数.

//后续会讲 页面之间传值

點擊查看更多內容
1人點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
移動開發工程師
手記
粉絲
2
獲贊與收藏
21

關注作者,訂閱最新文章

閱讀免費教程

感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消