Flutter基本概念常用命名

news/2024/8/27 21:20:26 标签: flutter, 学习

Flutter基本概念

  • 一切皆是Widgets
  • 多组件容器(Row、Column、Stack、Wrap)
  • 单组件容器(Container、Padding、Center、Align)
  • Flutter组件的规律

Widgets状态

  • stateful(有状态)

    当创建一个能随时间动态改变的widget,并且不依赖于其初始化状态。

    eg:Image

  • stateless(无状态)

    当创建的widget不需要管理任何形式的内部state时,则使用StatelessWidget。

    eg:Text

  • 注意:

    1. 创建一个Stateful Widget需要两个类,分别继承自StateFulWidget和State
    2. state对象包含了widget的state和widget的build()方法
    3. 当widget的state改变的时候,当调用setState()方法时,框架就会去调用build方法重绘widget
  • Code示例

    void main() => runApp(MyStatelessWidget(text:"StatelessWidgetExample"));
    class MyStatelessWidget extends StatelessWidget {
        final String text;
        MyStatelessWidget ({Key key, this.text}):super(key:key);
        
        
        Widget build(BuildContext context){
            return Center(
                child: Text(
                    text,
                    textDirection:TextDirection.ltr,
                ),
            );
        }
    }
    

运行和调试

  • 打印日志

    print

  • 断点

  • Dev Tool

VSCode插件

  • Flutter

    扩展增加对有效编辑、重构、运行和重新加载Flutter移动应用程序的支持

  • Dart

    扩展支持Dart编程语言

  • Flutter Widget Snippets

    帮助Flutter和Dart参阅开发

  • bracket-pair-colorizer-2.colors

    1)是常用flutter类和方法的集合

    2)提高开发速度

    3)消除样板

    4)支持复杂的小部件

Flutter常用命名

  • flutter doctor

    诊断当前的开发环境,有什么配得不对的

    [x]HTTP Host Availability

    1)打开文件:flutter\packages\flutter_tools\lib\src\http_host_validator.dart

    2)替换链接:

    ​ https://maven.google.com/ 改成 https://dl.google.com/dl/android/maven2/

    ​ kPubDevHttpHost的值 **改成 ** https://pub.flutter-io.cn/

    ​ kgCloudHttpHost的值 改成 https://storage.flutter-io.cn/

    3)删除文件:flutter\bin\cache\flutter_tools.snapshot

    [x]Android Studio (version 2021.2)

    flutter config --android-studio-dir <Android studio目录路劲>

    [x]cmdline-tools component is missing

    ​ Sdk下载:Android SDK Command-line Tools(latest)

    [x]Android license status unknown.

    ​ 控制台输入(全程输入Y):flutter doctor --android-licenses

  • flutter create xxx

    创建flutter项目

  • flutter run -d iPhone

    选择编译运行的环境-d(device)

  • flutter build xxx

    打包flutter项目

  • flutter devices

    查看当前可以运行的环境

  • flutter config

    1)查看flutter的配置信息

    2)添加(–no-analytics):在发送分析数据之前,禁止分析数据的统计

    3)添加(–enable-analytics):启动匿名分析

    4)添加(–disable-analytics):禁用匿名分析

    5)添加(–android-studio-dir <Android studio目录路劲>)

    6)添加( --enable-windows-desktop):设置windows启动


http://www.niftyadmin.cn/n/5559138.html

相关文章

R语言学习笔记8-并行计算

R语言学习笔记8-并行计算 简要说明使用parallel包使用foreach和doParallel包使用future包 简要说明 在R语言中&#xff0c;通过并行计算可以显著提升处理大数据集或执行耗时任务的效率。R提供了多种并行计算的方法&#xff0c;包括使用基础的parallel包和更高级的foreach和fut…

算法训练营第38天|1049. 最后一块石头的重量 II|494. 目标和|474.一和零

1049. 最后一块石头的重量 II 思路&#xff1a;本题思路为尽可能的将石头分成两堆。可以看成有一个容量为总和一半的背包&#xff0c;尽可能装满这个背包。 494. 目标和 思路&#xff1a;首先要把这道题转化为背包问题&#xff0c;这道题本质上是要将数组分成两个子集。其中一…

爬虫代理访问超时怎么解决?

一、为什么会出现访问超时 爬虫使用代理可能会遇到访问超时的情况&#xff0c;主要和以下几个方面有关&#xff1a; 1.代理服务器性能&#xff1a; 代理服务器作为中间层&#xff0c;承担着转发请求和响应的任务。如果代理服务器性能不佳或超载&#xff0c;请求的响应时间可能…

Kafka Producer发送消息流程之分区器和数据收集器

文章目录 1. Partitioner分区器2. 自定义分区器3. RecordAccumulator数据收集器 1. Partitioner分区器 clients/src/main/java/org/apache/kafka/clients/producer/KafkaProducer.java&#xff0c;中doSend方法&#xff0c;记录了生产者将消息发送的流程&#xff0c;其中有一步…

留学Essay写作可能面临哪些问题?

初到英国&#xff0c;Essay不会写&#xff1f;作业量太大&#xff0c;Essay来不及写完&#xff1f;硕士想申好学校&#xff0c;Essay需要高分但自己觉得很困难&#xff1f;上述烦恼是很多英国留学生会面临的问题&#xff0c;给留学生活带来了很大的困扰。 沐沐提醒大家&#xf…

Python基础语法篇(上)

Python基础语法&#xff08;上&#xff09; 一、基知二、基本数据类型&#xff08;一&#xff09;标准数据类型&#xff08;二&#xff09;数据类型转换 三、字符串基本操作&#xff08;一&#xff09;字符串的索引和切片&#xff08;二&#xff09;字符串的拼接 三、运算符四、…

[Labview] 表格单元格外边框 二维图片叠加绘图

最终效果如下所示 转行做Labview都没到三个月&#xff0c;主程居然让我做这么复杂的功能&#xff0c;真是看得起我/(ㄒoㄒ)/~~ 思路大致分为两步 1、确定每个框体的左上/右下单元格位置&#xff0c;转换为表格表格坐标并在二维图片上绘制生成&#xff1b; 2、为二维图片添加…

Go 语言中的互斥锁 Mutex

Mutex 是一种互斥锁,名称来自 mutual exclusion,是一种用于控制多线程对共享资源的竞争访问的同步机制。在有的编程语言中,也将其称为锁(lock)。当一个线程获取互斥锁时,它将阻止其他线程对该资源的访问,直到该线程释放锁。这可以防止多个线程对共享资源进行冲突访问,从而…