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 BaseAdapter适配器详解用法

    Android BaseAdapter适配器详解用法

    BaseAdapter是最基础的Adapter类,也是最实用最常用的一个类,但是相比于ArrayAdapter之类的,对初学者来说却比较难理解。所以本篇文章在这里介绍一下BaseAdapter
    2021-10-10
  • Android:下拉刷新+加载更多+滑动删除实例讲解

    Android:下拉刷新+加载更多+滑动删除实例讲解

    本文主要讲解 Android下拉刷新+加载更多+滑动删除的示例,这里整理了相关资料并附示例代码供大家学习参考,有需要的小伙伴可以参考下
    2016-08-08
  • Android使用Handler实现定时器与倒计时器功能

    Android使用Handler实现定时器与倒计时器功能

    Handler的最常见应用场景之一便是通过Handler在子线程中间接更新UI。这篇文章主要介绍了Android使用Handler实现定时器与倒计时器功能,需要的朋友可以参考下
    2018-02-02
  • Android读取手机通讯录联系人到自己项目

    Android读取手机通讯录联系人到自己项目

    这篇文章主要为大家详细介绍了Android读取手机通讯录联系人到自己项目,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-07-07
  • Android+OpenCV4.2.0环境配置详解(Android studio)

    Android+OpenCV4.2.0环境配置详解(Android studio)

    这篇文章主要介绍了Android+OpenCV4.2.0环境配置详解(Android studio),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • Android自定义图片选择器简单版

    Android自定义图片选择器简单版

    这篇文章主要为大家详细介绍了Android自定义图片选择器简单版,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-02-02
  • Android 使用压缩纹理的方案

    Android 使用压缩纹理的方案

    这篇文章主要介绍了Android 使用压缩纹理,本文介绍了什么是压缩纹理,以及加载压缩纹理的核心步骤,并在 Android OpenGLES 平台上实现了压缩纹理的显示,需要的朋友可以参考下
    2022-09-09
  • Android RecyclerView实现数据列表展示效果

    Android RecyclerView实现数据列表展示效果

    这篇文章主要为大家详细介绍了Android RecyclerView实现数据列表展示效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • Android绘制音乐播放器示波器

    Android绘制音乐播放器示波器

    这篇文章主要为大家详细介绍了Android绘制音乐播放器示波器的相关资料,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • Android如何防止多次点击事件

    Android如何防止多次点击事件

    大家都遇到这样一个问题吧,一个点击事件多次触发导致同样的内容提交了很多次,下面小编给大家带来一篇文章帮助大家解决android如何防止多次点击事件,对android防止多次点击事件相关只是感兴趣的朋友一起学习吧
    2015-12-12

最新评论