时间:2021-05-20
•文本组件
文本组件(text)负责显示文本和定义显示样式,下表为text常见属性
Text组件属性及描述
属性名 类型 默认值 说明 data String 要显示的文本 maxLines int 0 文本要显示的最大行数 style TextStyle null 文本样式,可定义文本的字体大小、颜色、粗细等 textAlign TextAlign TextAlign.center 文本水平方向的对齐方式,取值有center、end、justify、left、right、start、values textDirection TextDirection TextDirection.ltr 文本的书写方向,如从左到右、从右到左 textScaleFactor double 1.0 字体的缩放系数,比如,如果此属性设置的值为1.5,那么字体会被放大到150%,也就是说比原来大了50% textSpan TextSpan null 文本块,TextSpan里可以包含文本内容及样式
老样子,按照惯例附上Demo,创建多个文本组件来展示不同的文本样式,比如不同的颜色,不同的自号,不同的线形等。
import 'package:flutter/material.dart';void main() => runApp(DemoApp());class DemoApp extends StatelessWidget{ @override Widget build(BuildContext context) { return new MaterialApp( title: '文本组件Demo', home: new Scaffold( appBar: new AppBar( title: Text('文本组件Demo'), ), body: new Column( children: <Widget>[ new Text( '第一个文本Demo', style: new TextStyle( color: Colors.amberAccent, fontSize: 20, ), ), new Text( '第二个文本Demo', style: new TextStyle( color: Colors.deepOrange, fontSize: 20, ), textScaleFactor: 1.5,//放大50% ), new Text( '第三个文本Demo(瞎写的瞎写的瞎写的瞎写的瞎写的瞎写的瞎写的瞎写的瞎写的瞎写的瞎写的瞎写的瞎写的瞎写的瞎写的瞎写的瞎写的)', style: new TextStyle( color: Colors.blue, fontSize: 20, ), textAlign: TextAlign.end,//右对齐 ), new Text( '''第四个文本Demo 换到第二行,看看能不能显示的出来呢''', style: new TextStyle( fontSize: 20, color: Colors.green, ), maxLines: 2,//最大显示2行 ), new Text( '第五个Demo,设置水平方向文案超出屏幕后,显示...(瞎写的字瞎写的字瞎写的字瞎写的字瞎写的字瞎写的字瞎写的字瞎写的字)', style: new TextStyle( fontSize: 20, color: Colors.black, ), overflow: TextOverflow.ellipsis,//水平方向超出屏幕显示... ) ], ),//垂直方向排列 ), ); }}除了这些,还有很多其他的属性等着我们去尝试,我就不一一都写出来了,我也是刚开始接触Flutter,有些地方还不是很理解,希望以后接触的多了,可以豁然开朗吧!!!给大家看一下效果图:
•图标及按钮组件
•图标组件
图标组件(Icon)为展示图标的组件,该组件不可交互,要实现可交互,可以考虑使用IconButton组件,图标组件相关的组件有一下几个:
1.IconButton:可交互的Icon
2.Icons:框架自带Icon集合
3.IconTheme:Icon主题
4.ImageIcon:通过AssetImages或者其他图片显示Icon
图标组件常用属性表
属性名 类型 默认值 说明 color Color null 图标的颜色 icon IconData null 展示的具体图标,可以使用Icons图标列表中的任意一个图标即可,如Icons.phone表示一个电话的图标 style TextStyle null 文本样式 size Double 24.0 图标的大小,注意要带上小数位 textDirection TextDirection TextDirection.ltr 文本排列方向
附上Demo代码:
import 'package:flutter/material.dart';void main() => runApp(DemoApp());class DemoApp extends StatelessWidget{ @override Widget build(BuildContext context) { return new MaterialApp( title: '图标组件Demo', home: new IconDemo(), ); }}class IconDemo extends StatelessWidget { @override Widget build(BuildContext context) { return new Scaffold( appBar: new AppBar( title: new Text('图标组件Demo'), ), body: new Center( child: new Icon( Icons.android,//图标Icon color: Colors.green,//图标颜色,设置为绿色,原本的颜色是黑色的 size: 150.0,//Icon的大小 ), ), ); }}附上效果截图:
•图标按钮组件
图标按钮组件(IconButton)是基于Material Design风格的组件,他可以响应按下事件,并且按下时会带一个水波纹的效果,如果它的onPressed回调函数为null,那么这个按钮处于禁用的状态,并且不可以按下。
IconButton组件属性及描述
属性名 类型 默认值 说明 alignment AlignmentGeometry Alignment.center 定义IconButton的Icon对齐方式,默认为居中,Alignment是可以设置x,y偏移量的 icon Widget null 展示的具体图标,可以使用Icons图标列表中的任意一个图标 color Color null 图标颜色 disabledColor Color ThemeData.disableColor 图标组件禁用的颜色 iconSize double 24.0 图标大小 onPressed VoidCallBack null 当按钮按下时会触发此回调事件 tooltip String “” 当按钮按下时的组件提示语
写一个Demo,实现点击IconButton,出发onPressed回调并toast一句话,附上Demo代码:
import 'package:flutter/material.dart';import 'package:fluttertoast/fluttertoast.dart';void main() => runApp(DemoApp());class DemoApp extends StatelessWidget{ @override Widget build(BuildContext context) { return new MaterialApp( debugShowCheckedModeBanner: false, title: 'IconButtonDemo', home: new IconButtonDemo(), ); }}class IconButtonDemo extends StatelessWidget { @override Widget build(BuildContext context) { return new Scaffold( appBar: AppBar( title: Text('IconButton Demo'), leading: Icon(Icons.menu), actions: <Widget>[ IconButton( icon: Icon(Icons.search), ) ], ), body: new Center( child: new IconButton( icon: Icon(Icons.add_circle_outline), iconSize: 50.0, tooltip: '用户按下了按钮', disabledColor: Colors.green, onPressed: (){ Fluttertoast.showToast( msg: '点击了IconButton并且Toas了一句话', toastLength: Toast.LENGTH_LONG, textColor: Colors.deepOrange, gravity: ToastGravity.BOTTOM ); }), ), ); }}附上效果截图:
上面的代码除了演示了IconButton的简单使用,还对AppBar做了一些出了,在title的左右增加了两个图片,当然你也可以对其设置点击事件
注:这里和大家说一下在Flutter中怎么Toast出提示语,首先在pubspec.yaml引入fluttertoast包,点击Packages get,然后在你需要toast的地方import该库
//pubspec.yamlfluttertoast: ^2.2.11//import对应库import 'package:fluttertoast/fluttertoast.dart';• 凸起按钮组件
突起按钮组件(RaisedButton),往往我们在开发过程中,不会一直用系统的图标,那么如果一个按钮上需要我们添加自定义的文本,这样的按钮要怎么实现呢?
import 'package:flutter/material.dart';import 'package:fluttertoast/fluttertoast.dart';void main() => runApp(DemoApp());class DemoApp extends StatelessWidget{ @override Widget build(BuildContext context) { return new MaterialApp( debugShowCheckedModeBanner: false, title: 'IconButtonDemo', home: new IconButtonDemo(), ); }}class IconButtonDemo extends StatelessWidget { @override Widget build(BuildContext context) { return new Scaffold( appBar: AppBar( title: Text('IconButton Demo'), leading: Icon(Icons.menu), actions: <Widget>[ IconButton( icon: Icon(Icons.search), ) ], ), body: new Center( child: new RaisedButton( padding: const EdgeInsets.all(10.0),//内间距 splashColor: Colors.blue,//点击时按钮的颜色 elevation: 10, shape: BeveledRectangleBorder(//带斜角的长方形边框 borderRadius: BorderRadius.all(Radius.circular(5))//圆角 ), onPressed: (){ Fluttertoast.showToast( msg: '点击了IconButton并且Toas了一句话', toastLength: Toast.LENGTH_LONG, textColor: Colors.deepOrange, gravity: ToastGravity.BOTTOM ); }, //按钮内的文本 child: new Text( '我是RaisedButton按钮', style: TextStyle( color: Colors.green, fontSize: 20.0, ), ), ), ), ); }}附上效果截图:
总结
以上所述是小编给大家介绍的Flutter实现文本组件、图标及按钮组件的代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
易语言调用js需要用到拓展组件的脚本组件,在窗口创建完毕的事件里给脚本组件初始化设置下脚本组件的语言属性,在这里以JScript为例:脚本组件执行脚本的简单方法
1.实现效果2.实现原理在父组件中点击编辑按钮,将当前点击对象的id传给子组件,子组件根据id修改相应的内容父组件中代码://放置编辑按钮的位置
教大家简单的做一个小软件第一步,打开易语言,选择Windows窗口程序,第二步,在基本组件找到按钮组件第三步,双击按钮,然后写代码。第四步,运行测试效果第五步,
Flutter是借鉴React的开发思想实现的,在子组件的插槽上,React有this.props.children,Vue有。当然Flutter也有类似的Wi
微信小程序基础组件与导航组件详解:1.基础组件1.1图标icon1.2文本text1.3进度条progress2.导航组件(navigator)1.基础组件1.