flutter按钮点击事件传给delegate
在ios中,通常用block或者代理去实现,在flutter中,外部实现一个方法,把这个方法传给按钮,按钮内部用callback接受,ontap方法调用即可,实现如下
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
//定义函数类型
typedef StringValue = void Function(String);
class ImageBtn extends StatelessWidget {
//作为属性
StringValue callback;
ImageBtn({Key key,this.callback}) : super(key: key);
@override
Widget build(BuildContext context) {
return new GestureDetector(
onTap: () {
print('MyButton was tappedq!');
//调用
this.callback("testString");
},
child: ...
),
);
}
}
外部使用方法
//顶部按钮点击事件
void _ontap(String name){
print(name);
}
//实例对象时传进去
ImageBtn(callback:_ontap)
//另外一种写法,不传参数也可以,仅仅是invoke外部函数,
ImageBtn(callback:(){
//do sth...
})
注意:callback和外部的方法,参数类型要保持一致 总结:外部函数传给按钮,让按钮内部可以调用,通过无参数函数调用有参数也可以
- 原文作者:知识铺
- 原文链接:https://index.zshipu.com/geek/post/flutter/flutter-btn-delegate/
- 版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 4.0 国际许可协议进行许可,非商业转载请注明出处(作者,原文链接),商业转载请联系作者获得授权。
- 免责声明:本页面内容均来源于站内编辑发布,部分信息来源互联网,并不意味着本站赞同其观点或者证实其内容的真实性,如涉及版权等问题,请立即联系客服进行更改或删除,保证您的合法权益。转载请注明来源,欢迎对文章中的引用来源进行考证,欢迎指出任何有错误或不够清晰的表达。也可以邮件至 sblig@126.com