Flutter文本Text和输入框TextField组件使用示例

 更新时间:2023年08月06日 10:39:33   作者:Rocky_ruan  
这篇文章主要为大家介绍了Flutter文本Text和输入文本框TextField组件使用示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

一:文本组件Text

//文本
 const Text(
    String this.data, {//data必填项文本信息
    Key? key,
    this.style,//文本样式
    this.strutStyle,//文本字体样式
    this.textAlign,//文本应如何水平对齐
    this.textDirection,//相对TextAlign中的start、end而言有用(当start使用了ltr相当于end使用了rtl,也相当于TextAlign使用了left)
    this.locale,
    this.softWrap,//某一行中文本过长,是否需要换行。默认为true,
    this.overflow,//如何处理视觉溢出//TextOverflow.fade:将溢出的文本淡化为透明。TextOverflow.clip:剪切溢出的文本以修复其容器。TextOverflow.ellipsis:使用省略号表示文本已溢出。
    this.textScaleFactor,//每个逻辑像素的字体像素数
    this.maxLines,//本要跨越的可选最大行数
    this.semanticsLabel,
    this.textWidthBasis,
    this.textHeightBehavior,
  }) : assert(
         data != null,
         'A non-null String must be provided to a Text widget.',
       ),
       textSpan = null,
       super(key: key);
//富文本
 const Text.rich(
    InlineSpan this.textSpan, {
    Key? key,
    this.style,
    this.strutStyle,
    this.textAlign,
    this.textDirection,
    this.locale,
    this.softWrap,
    this.overflow,//如何处理视觉溢出//TextOverflow.fade:将溢出的文本淡化为透明。TextOverflow.clip:剪切溢出的文本以修复其容器。TextOverflow.ellipsis:使用省略号表示文本已溢出。
    this.textScaleFactor,//textScaleFactor字体显示倍率
    this.maxLines,//maxLines文字显示最大行数
    this.semanticsLabel,
    this.textWidthBasis,
    this.textHeightBehavior,
  }) : assert(
         textSpan != null,
         'A non-null TextSpan must be provided to a Text.rich widget.',
       ),
       data = null,
       super(key: key);

文本样式属性TextStyle

const TextStyle({
    this.inherit = true,//是否将null值替换为祖先文本样式中的值(例如,在TextSpan树中)。如果为false,则没有显式值的属性将恢复为默认值:白色,字体大小为10像素,采用无衬线字体。
    this.color,//文本颜色。如果指定了foreground,则此值必须为null。如自定义颜色:Color.fromRGBO(155, 155, 155, 1) 也可以使用Colors类里面自带的属性
    this.backgroundColor,//文本的背景颜色
    this.fontSize,//字体大小,默认14像素
    this.fontWeight,//字体厚度,可以使文本变粗或变细
//FontWeight.bold 常用的字体重量比正常重。即w700
//FontWeight.normal 默认字体粗细。即w400
//FontWeight.w100 薄,最薄
//FontWeight.w200 特轻
//FontWeight.w300 轻
//FontWeight.w400 正常/普通/平原
//FontWeight.w500 较粗
//FontWeight.w600 半粗体
//FontWeight.w700 加粗
//FontWeight.w800 特粗
//FontWeight.w900 最粗
    this.fontStyle,//字体风格:
//FontStyle.italic 使用斜体
//FontStyle.normal 使用直立
    this.letterSpacing,//水平字母之间的空间间隔(逻辑像素为单位)。可以使用负值来让字母更接近。
    this.wordSpacing,//单词之间添加的空间间隔(逻辑像素为单位)。可以使用负值来使单词更接近。
    this.textBaseline,//对齐文本的水平线:
//TextBaseline.alphabetic:文本基线是标准的字母基线
//TextBaseline.ideographic:文字基线是表意字基线;
//如果字符本身超出了alphabetic 基线,那么ideograhpic基线位置在字符本身的底部。
    this.height,//文本行与行的高度,作为字体大小的倍数(取值1~2,如1.2)
    this.leadingDistribution,
    this.locale,
    this.foreground,
    this.background,
    this.shadows,//文本的阴影可以利用列表叠加处理,例如shadows: [Shadow(color:Colors.black,offset: Offset(6, 3), blurRadius: 10)], color即阴影的颜色, offset即阴影相对文本的偏移坐标,blurRadius即阴影的模糊程度,越小越清晰
    this.fontFeatures,
    this.decoration,//文字的线性装饰,比如 TextDecoration.underline 下划线, //TextDecoration.lineThrough删除线
    this.decorationColor,//文本装饰线的颜色
    this.decorationStyle,//文本装饰线的风格
    this.decorationThickness,
    this.debugLabel,
    String? fontFamily,
    List<String>? fontFamilyFallback,
    String? package,
    this.overflow,
  }) : fontFamily = package == null ? fontFamily : 'packages/$package/$fontFamily',
       _fontFamilyFallback = fontFamilyFallback,
       _package = package,
       assert(inherit != null),
       assert(color == null || foreground == null, _kColorForegroundWarning),
       assert(backgroundColor == null || background == null, _kColorBackgroundWarning);

textAlign

文本应如何水平对齐enum:

可选值说明
TextAlign.center将文本对齐容器的中心
TextAlign.end对齐容器后缘上的文本
TextAlign.start对齐容器前缘上的文本
TextAlign.justify拉伸以结束的文本行以填充容器的宽度。即使用了decorationStyle才起效
TextAlign.left对齐容器左边缘的文本
TextAlign.right对齐容器右边缘的文本

栗子:

return Scaffold(
      body: Center(
      child: Text("人生,是一条漫长的路。无论是阳关大道,还是羊肠小道;无论是春花烂漫的日子,还是冬雪纷飞的季节;我们都要一路心存美好和希望,不卑不亢,不急不躁,长长的路,慢慢地走得之我幸,失之我命,有些时候,有些东西,不属于咱,就未必永远不属于咱,不要去争,不用去抢,让冥冥之中的浩瀚轨迹来预订。淡泊明志,才能宁静致远。",
        style: TextStyle(
          fontSize: 16,
          fontWeight: FontWeight.w500,//字体厚度
          fontStyle: FontStyle.italic,//斜体
          color: Color.fromRGBO(155, 155, 155, 1),//字体颜色
          height: 2,//文本行与行的高度,作为字体大小的倍数(取值1~2,如1.2)
          decoration: TextDecoration.underline,//下划线
          decorationColor: Colors.orange,
          decorationStyle: TextDecorationStyle.dashed//虚线
        ),
 textAlign: TextAlign.center,//对齐方式,居中对齐
      ),
      ),
    );

在上面的例子中,Text的所有文本内容只能按同一种样式,如果我们需要对一个Text内容的不同部分按照不同的样式显示,这时就可以使用TextSpan,它代表文本的一个“片段”。

TextSpan的定义

TextSpan用于指定文本片段的风格及手势交互

const TextSpan({
    this.text,//显示文本的组件
    this.children,////子组件
    TextStyle? style,//文本的样式
    this.recognizer,//指定手势交互
recognizer: TapGestureRecognizer()..onTap = () {},可以监听点击事件
    MouseCursor? mouseCursor,
    this.onEnter,
    this.onExit,
    this.semanticsLabel,
    this.locale,
    this.spellOut,
  }) : mouseCursor = mouseCursor ??
         (recognizer == null ? MouseCursor.defer : SystemMouseCursors.click),
       assert(!(text == null && semanticsLabel != null)),
       super(style: style);

栗子:

return Scaffold(
      body: Center(
        child: RichText(
          textScaleFactor: 5,//字体显示倍率
          overflow: TextOverflow.fade,//TextOverflow.fade:将溢出的文本淡化为透明。TextOverflow.clip:剪切溢出的文本以修复其容器。TextOverflow.ellipsis:使用省略号表示文本已溢出。
          textDirection: TextDirection.ltr,
          textAlign: TextAlign.left,//对齐方式
          text: TextSpan(
            children: [
              TextSpan(
                  text: "保证不对外公开或向第三方提供单个用户的注册资料及用户在使用网络服务时存储",
                  style: TextStyle(
                    color: Colors.black,
                  ),
                  recognizer: TapGestureRecognizer()..onTap = () {}),
              TextSpan(text: "安全协议",
                  style: TextStyle(
                    color: Colors.red,
                  ),
                  //点击事件
                  recognizer: TapGestureRecognizer()..onTap = () {
                    print("点击了安全协议");
                  })
            ]
          ),
        ),
      ),
    )
-----------------------------------------------------
//另一种方式实现父文本文本组装使用Text.rich()
//InlineSpan 是默认必须得加的
  InlineSpan span = TextSpan(children: [
      TextSpan(
          text: "保证不对外公开或向第三方提供单个用户的注册资料及用户在使用网络服务时存储",
          style: TextStyle(
            color: Colors.black,
          ),
          recognizer: TapGestureRecognizer()..onTap = () {}),
      TextSpan(
          text: "安全协议",
          style: TextStyle(
            color: Colors.red,
          ),
          //点击事件
          recognizer: TapGestureRecognizer()
            ..onTap = () {
              print("点击了安全协议");
            })
    ]);
    return Scaffold(
      body: Center(
        child: Text.rich(
          span,
          textScaleFactor: 5,
          //字体显示倍率
          overflow: TextOverflow.fade,
          //TextOverflow.fade:将溢出的文本淡化为透明。TextOverflow.clip:剪切溢出的文本以修复其容器。TextOverflow.ellipsis:使用省略号表示文本已溢出。
          textDirection: TextDirection.ltr,
          textAlign: TextAlign.left, //对齐方式
        ),
      ),
    );

TextRich实现富文本和Text.rich()都能实现富文本

二:输入框TextField

const TextField({
    Key? key,
    this.controller,//控制器,通过它可以获取文本内容,监听编辑文本事件,大多数情况下我们需要主动提供一个控制器
    this.focusNode,//焦点控制
    this.decoration = const InputDecoration(),//用于控制文本的外观,如提示文本、背景色、边框等
    TextInputType? keyboardType,//用于设置输入框的默认键盘类型
    this.textInputAction,//键盘动作图标按钮,他是一个枚举值
    this.textCapitalization = TextCapitalization.none,//大小写
    this.style,//样式
    this.strutStyle,
    this.textAlign = TextAlign.start,//文本框的在水平方向的对齐方式
    this.textAlignVertical,
    this.textDirection,
    this.readOnly = false,//只读属性默认false
    ToolbarOptions? toolbarOptions,//长按弹出按钮设置
    this.showCursor,//是否显示光标默认true
    this.autofocus = false,//是否自动获取焦点
    this.obscuringCharacter = '•',
    this.obscureText = false,//是否隐藏正在编辑的文本,用于密码输入场景
    this.autocorrect = true,
    SmartDashesType? smartDashesType,
    SmartQuotesType? smartQuotesType,
    this.enableSuggestions = true,
    this.maxLines = 1,//输入框的最大行数
    this.minLines,//最小行数
    this.expands = false,
    this.maxLength,//文本框的最大长度
    @Deprecated(
      'Use maxLengthEnforcement parameter which provides more specific '
      'behavior related to the maxLength limit. '
      'This feature was deprecated after v1.25.0-5.0.pre.',
    )
    this.maxLengthEnforced = true,
    this.maxLengthEnforcement,//当文本长度超出文本框长度时如何处理
    this.onChanged,//输入框改变时候的回调函数,也可以通过controller来监听
    this.onEditingComplete,//输入完后触发的回调函数,不接受参数
    this.onSubmitted,//接收ValueChanged<String>的参数
    this.onAppPrivateCommand,
    this.inputFormatters,//用于指定输入格式,可以用于检验格式
    this.enabled,//为bool时,输入框将变为禁用状态
    this.cursorWidth = 2.0,//用于自定义输入框光标宽度
    this.cursorHeight,//用于自定义输入框光标高度
    this.cursorRadius,//用于自定义输入框光标圆角
    this.cursorColor,//用于自定义输入框光标颜色
    this.selectionHeightStyle = ui.BoxHeightStyle.tight,
    this.selectionWidthStyle = ui.BoxWidthStyle.tight,
    this.keyboardAppearance,//键盘外观
    this.scrollPadding = const EdgeInsets.all(20.0),
    this.dragStartBehavior = DragStartBehavior.start,
    this.enableInteractiveSelection = true,
    this.selectionControls,
    this.onTap,//点击事件
    this.mouseCursor,//鼠标悬停。web可以了解
    this.buildCounter,//inputDecorator.counter自定义小工具
    this.scrollController,//滚动控制器
    this.scrollPhysics,//滚动物理效果
    this.autofillHints = const <String>[],//自动填充
    this.clipBehavior = Clip.hardEdge,
    this.restorationId,
    this.enableIMEPersonalizedLearning = true,
  }) : assert(textAlign != null),
       assert(readOnly != null),
       assert(autofocus != null),
       assert(obscuringCharacter != null && obscuringCharacter.length == 1),
       assert(obscureText != null),
       assert(autocorrect != null),
       smartDashesType = smartDashesType ?? (obscureText ? SmartDashesType.disabled : SmartDashesType.enabled),
       smartQuotesType = smartQuotesType ?? (obscureText ? SmartQuotesType.disabled : SmartQuotesType.enabled),
       assert(enableSuggestions != null),
       assert(enableInteractiveSelection != null),
       assert(maxLengthEnforced != null),
       assert(
         maxLengthEnforced || maxLengthEnforcement == null,
         'maxLengthEnforced is deprecated, use only maxLengthEnforcement',
       ),
       assert(scrollPadding != null),
       assert(dragStartBehavior != null),
       assert(selectionHeightStyle != null),
       assert(selectionWidthStyle != null),
       assert(maxLines == null || maxLines > 0),
       assert(minLines == null || minLines > 0),
       assert(
         (maxLines == null) || (minLines == null) || (maxLines >= minLines),
         "minLines can't be greater than maxLines",
       ),
       assert(expands != null),
       assert(
         !expands || (maxLines == null && minLines == null),
         'minLines and maxLines must be null when expands is true.',
       ),
       assert(!obscureText || maxLines == 1, 'Obscured fields cannot be multiline.'),
       assert(maxLength == null || maxLength == TextField.noMaxLength || maxLength > 0),
       // Assert the following instead of setting it directly to avoid surprising the user by silently changing the value they set.
       assert(
         !identical(textInputAction, TextInputAction.newline) ||
         maxLines == 1 ||
         !identical(keyboardType, TextInputType.text),
         'Use keyboardType TextInputType.multiline when using TextInputAction.newline on a multiline TextField.',
       ),
       assert(clipBehavior != null),
       assert(enableIMEPersonalizedLearning != null),
       keyboardType = keyboardType ?? (maxLines == 1 ? TextInputType.text : TextInputType.multiline),
       toolbarOptions = toolbarOptions ?? (obscureText ?
         const ToolbarOptions(
           selectAll: true,
           paste: true,
         ) :
         const ToolbarOptions(
           copy: true,
           cut: true,
           selectAll: true,
           paste: true,
         )),
       super(key: key);

1.keyboardType 为键盘类型

和尚理解整体分为数字键盘和字母键盘等;根据设置的键盘类型,键盘会有差别;

a. 数字键盘

--1-- datetime 键盘上可随时访问 : 和 /;
--2-- phone 键盘上可随时访问 # 和 *;
--3-- number 键盘上可随时访问 + - * /

b. 字母键盘

--1-- emailAddress 键盘上可随时访问 @ 和 .;
--2-- url 键盘上可随时访问 / 和 .;
--3-- multiline 适用于多行文本换行;
--4-- text 默认字母键盘;

2.textInputAction 

通常为键盘右下角操作类型,类型众多,建议多多尝试

     * none 为不弹出键盘
     * unspecified 换行
     * none 为不弹出键盘
     * done 完成或者done
     * go  前往或者go
     * search 搜索或者search
     * send  发送或者send
     * next 下一项或者next
     * previous
     * continueAction 继续或者 continue
     * join 加入或者join
     * route 路线或者route
     * emergencyCall 紧急电话
     * newline 换行或者newline

栗子:

//定义一个controller
    TextEditingController _unameController = TextEditingController();
    _unameController.addListener(() {
      print("你输入的内容为${_unameController.text}");
    });
    return Scaffold(
        body: Center(
      child: TextField(
        //设置监听
        controller: _unameController,
        autofocus: true,
        keyboardType: TextInputType.text,
        decoration: InputDecoration(
          icon: Icon(Icons.person),
          labelText: "用户名",
          hintText: "请输入手机号",
          // errorText: "没有输入任何内容"),
        ),
        maxLines: 1,
        //注意执行顺序onTap->onChanged->onEditingComplete->onSubmitted
        onTap: (){
          print("onTap");
        },
        onChanged: (string) {
          print("onChanged$string");
        },
        onEditingComplete: () {
          print("onEditingComplete");
        },
        onSubmitted: (string) {
          print("onSubmitted$string");
        },
      ),
    ));

输出的结果:说明了执行顺序onTap->onChanged->onEditingComplete->onSubmitted

I/flutter (14614): onTap
I/flutter (14614): 你输入的内容为你好
I/flutter (14614): onChanged你好
I/flutter (14614): 你输入的内容为你好世界//这个是监听TextEditingController打印的和onChanged类似
I/flutter (14614): onChanged你好世界
I/flutter (14614): onEditingComplete
I/flutter (14614): onSubmitted你好世界

以上就是Flutter文本Text和输入文本框TextField组件使用示例的详细内容,更多关于Flutter文本输入文本框组件的资料请关注脚本之家其它相关文章!

相关文章

  • Android手势操作简单实例讲解

    Android手势操作简单实例讲解

    这篇文章主要为大家详细介绍了Android手势操作简单实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • Android 启动activity的4种方式及打开其他应用的activity的坑

    Android 启动activity的4种方式及打开其他应用的activity的坑

    这篇文章主要介绍了Android 启动activity的4种方式及打开其他应用的activity的坑的相关资料,需要的朋友可以参考下
    2016-05-05
  • android调用WebService实例分析

    android调用WebService实例分析

    这篇文章主要介绍了android调用WebService的方法,以实例形式较为详细的分析了WebService的调用原理与具体使用方法,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-10-10
  • Android为TextView添加字体库和设置描边的方法

    Android为TextView添加字体库和设置描边的方法

    本篇文章主要介绍了Android为TextView添加字体库和设置描边的方法,具有一定的参考价值,有兴趣的可以了解一下
    2017-09-09
  • APK包名修改 请问如何修改APK包名

    APK包名修改 请问如何修改APK包名

    今天,想在android手机上安装两个相同的应用,本以为可以安装不同版本的,试了几次,均相互覆盖了,于是,只能设法修改apk所对应的包名(package name),需要了解的朋友可以参考下
    2012-12-12
  • Android自定义view利用PathEffect实现动态效果

    Android自定义view利用PathEffect实现动态效果

    这篇文章主要为大家详细介绍了Android自定义view利用PathEffect实现动态效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • Android Glide常见使用方式讲解

    Android Glide常见使用方式讲解

    对于Glide这个加载图片的框架,很多人都在用,我之前使用的是ImageLoader,最近查资料时,发现Glide才是Google推荐的加载图片框架,功能非常强大,而且还有Google专人维护,要知道,ImageLoader已经没人维护了,除了问题可没人解答。所以有必要整理一下Glide的使用
    2023-01-01
  • Android如何在一个TextView中设置不同字体大小、不同字体颜色封装

    Android如何在一个TextView中设置不同字体大小、不同字体颜色封装

    在开发过程中遇到过这样一种业务,有很多单行文本字体,字符串中每一部分的字体样式、大小、颜色都不相同,传统的做法是放多个TextView以达到效果,这篇文章主要介绍了android在一个TextView中设置不同字体大小、不同字体颜色封装,需要的朋友可以参考下
    2024-07-07
  • Android应用的LinearLayout中嵌套RelativeLayout的布局用法

    Android应用的LinearLayout中嵌套RelativeLayout的布局用法

    这篇文章主要介绍了Android应用的LinearLayout中嵌套RelativeLayout的布局用法,文后还给出了线性布局中一些组件位置的调试经验,需要的朋友可以参考下
    2016-04-04
  • Android NotificationListenerService通知监听服务使用

    Android NotificationListenerService通知监听服务使用

    这篇文章主要为大家介绍了Android NotificationListenerService通知监听服务使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11

最新评论