为了账号安全,请及时绑定邮箱和手机立即绑定

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人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消