Flutter质感设计之直接输入

 更新时间:2018年08月23日 11:02:30   投稿:lijiao  
这篇文章主要为大家详细介绍了Flutter质感设计之直接输入,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

Input控件是质感设计的文本输入控件,它在用户每次输入时都会调用onChanged回调时,都会更新字段值,还可以实时的对用户输入进行响应。

import 'package:flutter/material.dart';

class MyApp extends StatefulWidget {
 @override
 _MyApp createState() => new _MyApp();
}

class _MyApp extends State<MyApp> {

 // InputValue:文本输入字段的配置信息
 InputValue _phoneValue = const InputValue();
 InputValue _passwordValue = const InputValue();

 void _showMessage(String name) {
  showDialog<Null>(
   context: context,
   child: new AlertDialog(
    content: new Text(name),
    actions: <Widget>[
     new FlatButton(
      onPressed: () {
       Navigator.pop(context);
      },
      child: new Text('确定')
     )
    ]
   )
  );
 }

 @override
 Widget build(BuildContext context) {
  return new Scaffold(
   appBar: new AppBar(
    title: new Text('直接输入')
   ),
   body: new Column(
    children: <Widget> [
     new Input(
      // value:文本输入字段的当前状态
      value: _phoneValue,
      // keyboardType:用于编辑文本的键盘类型
      keyboardType: TextInputType.number,
      // icon:在输入字段旁边显示的图标
      icon: new Icon(Icons.account_circle),
      // labelText:显示在输入字段上方的文本
      labelText: '手机',
      // hintText:要在输入字段中内嵌显示的文本
      hintText: '请输入手机号码',
      // onChanged:正在编辑的文本更改时调用
      onChanged: (InputValue value) {
       setState((){
        _phoneValue = value;
       });
      }
     ),
     new Input(
      value: _passwordValue,
      // obscureText:是否隐藏正在编辑的文本
      obscureText: true,
      labelText: '密码',
      onChanged: (InputValue value) {
       setState((){
        _passwordValue = value;
       });
      },
      // onSubmitted:当用户在键盘上点击完成编辑时调用
      onSubmitted: (InputValue value) {
       if(value.text.length<6){
        _showMessage('密码不少于6位');
       }
      }
     ),
     new RaisedButton(
      child: new Text('提交'),
      onPressed: () {
       _showMessage(_phoneValue.text+'/'+_passwordValue.text);
      }
     )
    ]
   )
  );
 }
}

void main() {
 runApp(new MaterialApp(
  title: 'Flutter Demo',
  home: new MyApp()
 ));
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android 使用Kotlin自定义View的方法教程

    Android 使用Kotlin自定义View的方法教程

    最近想加强一下自定义view方面的学习,正好也在学习Kotlin,所以就尝试着用Kotlin写一下简单的自定义view,下面这篇文章主要给大家介绍了关于Android使用Kotlin自定义View的方法教程,需要的朋友可以参考下。
    2017-12-12
  • Android 基础入门教程——开发环境搭建

    Android 基础入门教程——开发环境搭建

    这篇文章主要介绍了Android 如何搭建开发环境,文中讲解非常细致,帮助大家开始学习Android,想要学习Android的朋友可以了解下
    2020-06-06
  • Android九宫格手势密码代码设计

    Android九宫格手势密码代码设计

    这篇文章主要为大家详细介绍了Android九宫格手势密码的代码设计思路,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • Android实现加载时提示“正在加载,请稍后”的方法

    Android实现加载时提示“正在加载,请稍后”的方法

    在现在的很多应用中,当在加载的时候,如果页面动态数据较多,会有很长一段时间的空白页面,如果加上这个页面正在加载的提示,使得应用更加人性化。这篇文章就给大家分享了在 Android实现加载时提示“正在加载,请稍后”的方法,有需要的朋友们可以参考借鉴。
    2016-10-10
  • Flutter渲染原理深入解析

    Flutter渲染原理深入解析

    众所周知 Flutter是由Google推出的开源的高性能跨平台框架,一个2D渲染引擎。在Flutter中,Widget是Flutter用户界面的基本构成单元,可以说一切皆Widget。下面来看下Flutter框架的整体结构组成
    2023-04-04
  • Android单元测试之对Activity的测试示例

    Android单元测试之对Activity的测试示例

    本篇文章主要介绍了Android单元测试之对Activity的测试示例,具有一定的参考价值,有兴趣的可以了解一下
    2017-08-08
  • Android获取apk程序签名信息代码示例

    Android获取apk程序签名信息代码示例

    这篇文章主要介绍了Android获取apk程序签名信息的方法,大家参考使用吧
    2013-11-11
  • Android实现简单的分批加载ListView

    Android实现简单的分批加载ListView

    这篇文章主要介绍了Android实现简单的分批加载ListView的相关资料,需要的朋友可以参考下
    2016-03-03
  • BroadcastReceiver静态注册案例详解

    BroadcastReceiver静态注册案例详解

    这篇文章主要为大家详细介绍了BroadcastReceiver静态注册案例,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • AOSP源码下载及问题小结

    AOSP源码下载及问题小结

    这篇文章主要介绍了AOSP源码下载,包括源码下载示例,文中给大家介绍了配置下载方法,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03

最新评论