最新公告
  • 欢迎您光临网站无忧模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Dart 编码规范:`多态` 和 `控制反转`最佳实践 - 掘金

    正文概述 掘金(李小轰_rex)   2021-11-24   701

    「这是我参与11月更文挑战的第三天,活动详情查看:2021最后一次更文挑战」

    前言

    我们通常都知道程序设计要依赖抽象,提高复用性,做到对扩展开放,对修改关闭。贯彻SOLID五大原则的最重要法宝就是抽象继承多态是一种手段,下面,通过简单 demo 介绍 flutter 开发中常用的最佳实践。

    举栗子?

    /// 不推荐,避免把逻辑放在公共底层处理
    class TestWidget extends StatefulWidget {
      const TestWidget({Key? key}) : super(key: key);
    
      @override
      TestWidgetState createState() => TestWidgetState();
    }
    
    class TestWidgetState extends State<TestWidget> {
      dynamic param;
      Widget childWidget = Container();
    
      ///提供给外部调用
      void update(dynamic value) {
        setState(() {
          param = value;
          _updateBody();
        });
      }
      
      void _updateBody(){
        if(param == null){
          childWidget = Container();
          return;
        }
        switch(param.runtimeType){
          case A:
            childWidget = AWidget(a: param as A,);
            break;
          case B:
            childWidget = BWidget(b: param as B,);
            break;
          default:
            childWidget = Container();
            break;
        }
      }
    
      @override
      Widget build(BuildContext context) {
        return Container(
          child: childWidget,
        );
      }
    }
    

    如上的写法是不推荐的,应该进行依赖倒置,将可变的部分放上层处理,保证底层干净,如下:

    方式一:通过传参构造器进行控制反转

    typedef ChildBuilder = Widget Function(dynamic param);
    class TestWidget extends StatefulWidget {
      final ChildBuilder builder;
    
      const TestWidget({Key? key, required this.builder}) : super(key: key);
    
      @override
      TestWidgetState createState() => TestWidgetState();
    }
    
    class TestWidgetState extends State<TestWidget> {
      dynamic param;
    
      void update(dynamic value) {
        setState(() {
          param = value;
        });
      }
      
      @override
      Widget build(BuildContext context) {
        return Container(
          child: widget.builder(param),
        );
      }
    }
    
    
    ///外部使用 TestWidget
    Widget _builder(dynamic param){
      if (param == null) {
        return Container();
      }
      switch (param.runtimeType) {
        case A:
          return AWidget(
            a: param as A,
          );
        case B:
          return BWidget(
            b: param as B,
          );
        default:
          return Container();
      }
    }
    
    return TestWidget(builder: _builder);
    

    方式二:通过继承 + 泛型进行解耦

    /// 将 TestWidget 改成抽象类并指定泛型
    abstract class TestWidget<T> extends StatefulWidget {
      const TestWidget({Key? key}) : super(key: key);
    
      Widget childBuilder(T param);
    
      @override
      TestWidgetState<T> createState() => TestWidgetState<T>();
    }
    
    class TestWidgetState<T> extends State<TestWidget> {
      T? param;
      Widget childWidget = Container();
    
      void update(T value) {
        setState(() {
          param = value;
        });
      }
    
      @override
      Widget build(BuildContext context) {
        return Container(
          child: widget.childBuilder(param),
        );
      }
    }
    
    /// 实例A
    class ATestWidget extends TestWidget<A> {
      const ATestWidget({Key? key}) : super(key: key);
    
      @override
      Widget childBuilder(A param) {
        return AWidget(a: param);
      }
    }
    
    /// 实例B
    class BTestWidget extends TestWidget<B> {
      const BTestWidget({Key? key}) : super(key: key);
    
      @override
      Widget childBuilder(B param) {
        return BWidget(b: param);
      }
    }
    

    下载网 » Dart 编码规范:`多态` 和 `控制反转`最佳实践 - 掘金

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元