手把手入门Fish-Redux开发flutter(上)

2023-12-18 15:38

本文主要是介绍手把手入门Fish-Redux开发flutter(上),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文适合已经入门flutter,没有了解过Redux,但对Fish-Redux感兴趣的同学。

1 Fish-Redux介绍

众所周知,redux是一个前端的状态管理框架。

而 Fish-Redux 是阿里闲鱼团队开发的flutter应用框架。用其官方文档的原文描述就是 “Fish Redux 是一个基于 Redux 数据管理的组装式 flutter 应用框架, 它特别适用于构建中大型的复杂应用。”

1.1 Fish-Redux组成部分

作为没有前端经验的小白,初始fish-redux会对各种概念一脸懵逼,下面我们来梳理一下。

page

page代表一个页面,继承自 component。它由view(即展示ui的Widget)、state、reducer、effect等组成

state

state用来保存 page/component(页面/组件)的状态,即存放数据

action

action是我们定义的意图。我们需要处理某些操作或事件时,通过发送(dispatch)特定的 action,让对应action的接收者进行处理。

action包含两个字段:

  • type:action的类型
  • payload:action搭载的参数

reducer

reducer的作用是接收某个意图(action),然后对数据做出修改,即更新状态(state)。

effect

effect的用法跟 reducer 类似,但是责任不同。他负责处理“副作用”,这是函数式编程的概念。在这里简单地理解为,reducer是负责(state)的更新,effect 负责 state 更新之外的事情。

store

store维持全局的状态(state),应用只有一个单一的 store 。

1.2 Fish-Redux流程图

根据个人的理解,简单地绘制了下图
fish_redux_flow.jpg

 

image

 

首先看左上:用户进行某个操作----->然后调用context.dispatch方法发送一个由ActionCreator创建的Action----->effect接收并处理,然后dispatch给reducer----->reducer接收并产生新的state----->state更新导致界面显示的刷新

2 引入Fish-Redux

2.1 创建项目

首先创建一个flutter项目,取名叫fish_demo

 

image

image

这是创建好的默认项目

 

image

2.2 引入fish-redux

然后我们引入fish-redux:首先打开pubspec.yaml文件,在 dependencies 下面加上 fish_redux: ^0.2.7 ,点击 packages get ,最后查看结果。
引入fish-redux

image

 

3 安装插件

fish-redux团队我们提供了一个插件,方便我们使用fish-redux,简化了文件创建的过程。
插件名字叫:FishReduxTemplate

image

插件安装成功:

image

4 创建应用的根 Widget

新建一个 app.dart 用来创建应用的根Widget。
我们定义一个createApp()方法来初始化app的信息,包括标题、主题、页面路由。app.dart如下


import 'package:fish_redux/fish_redux.dart';
import 'package:flutter/material.dart';Widget createApp() {final AbstractRoutes routes = PageRoutes(pages: <String, Page<Object, dynamic>>{},);return MaterialApp(title: 'FishDemo',theme: ThemeData(primarySwatch: Colors.blue,),onGenerateRoute: (RouteSettings settings) {return MaterialPageRoute<Object>(builder: (BuildContext context) {return routes.buildPage(settings.name, settings.arguments);});},);
}

然后修改默认的 main.dart,让其运行我们的app。main.dart如下

import 'package:flutter/material.dart';
import 'app.dart';void main() => runApp(createApp());

5 第一个fish-redux页面

首先新建一个 package 命名为 entrance ,表示应用入口界面。

右键点击 entrance ----> New ----> FishReduxTemplate ,选择后弹出窗口如下:

image

 

我们采用默认勾选,并命名这个 module 为 Entrance。
然后得到的 Entrance 页如下

 

image

从 page.dart 我们可以看出一个 page 的结构。page.dart如下

import 'package:fish_redux/fish_redux.dart';
import 'effect.dart';
import 'reducer.dart';
import 'state.dart';
import 'view.dart';class EntrancePage extends Page<EntranceState, Map<String, dynamic>> {EntrancePage(): super(initState: initState,effect: buildEffect(),reducer: buildReducer(),view: buildView,dependencies: Dependencies<EntranceState>(adapter: null,slots: <String, Dependent<EntranceState>>{}),middleware: <Middleware<EntranceState>>[],);}

Entrance 页面的视图部分由 view.dart 负责,我们对其进行修改,加一个button进去。view.dart修改后如下。

import 'package:fish_redux/fish_redux.dart';
import 'package:flutter/material.dart';
import 'action.dart';
import 'state.dart';Widget buildView(EntranceState state, Dispatch dispatch, ViewService viewService) {return Scaffold(appBar: AppBar(backgroundColor: Colors.blue,title: Text('入口页面'),),body: Container(child: Center(child: RaisedButton(padding: EdgeInsets.fromLTRB(40, 0, 40, 0),color: Colors.green,child: Text("进入",style: TextStyle(color: Colors.white),),onPressed: () {//todo 点击事件}),),),);
}

最后我们将 Entrance 页面配置到app全局页面路由中,并将其设置为 app 默认的 home 页面。打开 app.dart:(注释标记的两行)


import 'package:fish_redux/fish_redux.dart';
import 'package:flutter/material.dart';import 'entrance/page.dart';Widget createApp() {final AbstractRoutes routes = PageRoutes(pages: <String, Page<Object, dynamic>>{'entrance_page': EntrancePage(),  //在这里添加页面},);return MaterialApp(title: 'FishDemo',theme: ThemeData(primarySwatch: Colors.blue,),home: routes.buildPage('entrance_page', null),  //把他作为默认页面onGenerateRoute: (RouteSettings settings) {return MaterialPageRoute<Object>(builder: (BuildContext context) {return routes.buildPage(settings.name, settings.arguments);});},);
}

运行效果如下

 

image

下一篇将了解更多关于fish-redux的使用。

这篇关于手把手入门Fish-Redux开发flutter(上)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/508945

相关文章

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

C#图表开发之Chart详解

《C#图表开发之Chart详解》C#中的Chart控件用于开发图表功能,具有Series和ChartArea两个重要属性,Series属性是SeriesCollection类型,包含多个Series对... 目录OverviChina编程ewSeries类总结OverviewC#中,开发图表功能的控件是Char

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE

Python开发围棋游戏的实例代码(实现全部功能)

《Python开发围棋游戏的实例代码(实现全部功能)》围棋是一种古老而复杂的策略棋类游戏,起源于中国,已有超过2500年的历史,本文介绍了如何用Python开发一个简单的围棋游戏,实例代码涵盖了游戏的... 目录1. 围棋游戏概述1.1 游戏规则1.2 游戏设计思路2. 环境准备3. 创建棋盘3.1 棋盘类

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设