Flutter笔记--Fluro

Flutter本身带有路由,但目前流行的是第三方路由Fluro,它也相对成熟,看看其用法:

pubspec.yaml文件里,注册版本依赖,代码如下:

dependencies:
  flutter:
    sdk: flutter

  # The following adds the Cupertino Icons font to your application.
  # Use with the CupertinoIcons class for iOS style icons.

  fluro: ^1.6.4

dev_dependencies:

fluro_application.dart

import 'package:fluro/fluro.dart';

class FluroApplication{
  static FluroRouter router;
}

fluro_routes.dart


import 'package:flutter/material.dart';
import 'package:fluro/fluro.dart';
import 'package:flutterplay/routes/route_handlers.dart';

class FluroRoutes {
  
  static String testbase = "/testbase";

  static void configureRoutes(FluroRouter router){
    router.notFoundHandler = new Handler(
        handlerFunc: (BuildContext context,Map<String,List<String>> params){
          print("route is not find !");
        });

    router.define(testbase, handler: testHandler);
  }
}

​

route_handlers.dart

import 'package:fluro/fluro.dart';
import 'package:flutter/material.dart';
import 'package:flutterplay/pages/register/TestBasePage.dart';

var testHandler = new Handler(
    handlerFunc: (BuildContext context, Map<String, List<String>> params) {
      return new TestBasePage();
    });

main.dart

void main() {

  runApp(MyApp());
}

class MyApp extends StatelessWidget {

  MyApp() {
  //初始化Fluro
    final router = new FluroRouter();
    FluroRoutes.configureRoutes(router);
    FluroApplication.router = router;
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
        home:Scaffold(
          appBar: AppBar(
              title: Text('Flutter Demo')
          ),
          body: HomePage(),
        )

}

HomePage

class HomePage extends StatefulWidget {
  HomePage({Key key}) : super(key: key);

  _HomePage createState() => _HomePage();
}

 class _HomePage extends State<HomePage> {
  @override
  Widget build(BuildContext context) {
    return Column(
      crossAxisAlignment: CrossAxisAlignment.center,
      mainAxisAlignment: MainAxisAlignment.center,
      children: <Widget>[
        RaisedButton(
            child: Text("TestBase"),
            onPressed: () {
             //跳转到TestBase页面
              FluroApplication.router.navigateTo(context,'/testbase',transition: TransitionType.fadeIn);
            }
        ]),
   );
 }
}

TestBase

import 'package:flutter/material.dart';

class TestBase extends StatelessWidget {
 
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar:AppBar(
        title: Text("TestBase"),
      ) ,
      body: Text("TestBase Play"),
    );
  }
}

注意: 每增加一个路由,都需要在router文件和handler文件进行配置。

参考:fluro

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Flutter中的TextField是一个常用的输入控件,它允许用户在应用程序中输入文本。 TextField通常用于表单中,可以接收用户输入的文本,比如用户名、密码、电子邮件地址等。 以下是一个基本的TextField示例: ```dart TextField( decoration: InputDecoration( hintText: '请输入文本', ), ); ``` 在上面的示例中,我们使用了decoration属性来设置TextField的外观,其中hintText属性用于设置提示文本。 TextField还有许多其他的属性可以设置,比如maxLength(允许输入的最大长度)、keyboardType(键盘类型)、obscureText(是否隐藏输入内容)等等。 下面是一个更完整的TextField示例: ```dart class MyTextField extends StatefulWidget { @override _MyTextFieldState createState() => _MyTextFieldState(); } class _MyTextFieldState extends State<MyTextField> { final TextEditingController _controller = TextEditingController(); @override Widget build(BuildContext context) { return TextField( controller: _controller, maxLength: 10, keyboardType: TextInputType.text, obscureText: true, decoration: InputDecoration( hintText: '请输入文本', labelText: '文本框', prefixIcon: Icon(Icons.text_fields), suffixIcon: IconButton( icon: Icon(Icons.clear), onPressed: () { setState(() { _controller.clear(); }); }, ), border: OutlineInputBorder(), ), onChanged: (value) { print('输入的文本为:$value'); }, ); } } ``` 在上面的示例中,我们使用了TextEditingController来控制TextField的文本内容,maxLength属性限制了用户输入的最大长度为10,keyboardType属性指定了键盘类型为文本类型,obscureText属性设置为true表示隐藏输入内容。 此外,我们还设置了decoration属性来自定义TextField的外观,包括了输入提示文本、标签文本、前缀图标、后缀图标和边框样式等。 最后,我们通过onChanged回调函数来监听用户输入的文本,并打印出来。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值