1.Dart基础快速入门

image

声明:Flutter专栏文档均来自慕课网 https://coding.imooc.com/class/321.html

Dart基础知识

  • 程序入口

  • 控制台输出

  • 变量

  • 检查null或零

  • Functions

  • 异步编程

    • Futures

    • async 和 await

在本节中我们主要对标JavaScript来讲解Dart与JavaScript的异同,对JavaScript还不熟悉的小伙伴可以省略JavaScript部分,直接学习Flutter部分。

程序入口

JavaScript没有预定义的入口函数,但在Dart中,每个app都必须有一个顶级的main()函数作为应用程序的入口点。

练一练DartPad

DartPadDart的一个线上playground,提供Dart线上playground还有:Online Dart Compiler

控制台输出

要在Dart中打印到控制台,可使用print

练一练DartPad

变量

Dart是类型安全的 - 它使用静态类型检查和运行时的组合,检查以确保变量的值始终与变量的静态值匹配 类型。尽管类型是必需的,但某些类型注释是可选的,因为 Dart会执行类型推断。

创建和分配变量

在JavaScript中,无法定义变量类型。

在Dart中, 变量必须是明确的类型或系统能够解析的类型。

练一练DartPad

有关更多信息,可参考Dart's Type System

默认值

在JavaScript中,未初始化的变量是undefined

在Dart中,未初始化的变量的初始值为null

注意:数字在Dart中也被当成对象,所以只要是带有数字类型的未初始化变量的值都是“null”。

尝试一下DartPad

有关更多信息, 可参考Dart官网关于变量的介绍。

检查null或零

在JavaScript中,1或任何非null对象的值被视为true。

Dart中,只有布尔值“true”被视为true

练一练DartPad

前方高能

Dart null检查最佳实践

Dart 1.12开始,null-aware运算符可用帮助我们做null检查:

?.运算符在左边为null的情况下会阻断右边的调用,?? 运算符主要作用是在左侧表达式为 null 时为其设置默认值。

对于表达式:

outgoing[a]?.contains(b)

如果outgoing为null或outgoing[a]为null或contains(b)的值为null,都会导致表达式为null。

大家看一下下面预计的执行结果:

练一练

技巧:获取一个对象中数组的长度:searchModel?.data?.length ?? 0

Functions

Dart和JavaScript函数类似。主要区别是声明:

练一练DartPad

关于functions的更多内容可参考dart官方文档functions

异步编程

Futures

与JavaScript一样,Dart支持单线程执行。在JavaScript中,Promise对象表示异步操作的最终完成(或失败)及其结果值,Dart使用 Future 来表示异步操作:

练一练:DartPad

关于Futures的更多内容可参考dart官方文档Futures

async await

async函数声明定义了一个异步函数。

在JavaScript中,async函数返回一个Promiseawait运算符是用来等待Promise:

在Dart中,async函数返回一个Future,函数的主体是稍后执行。await 运算符用于等待Future:

练一练DartPad

关于Futures的更多内容可参考dart官方文档async and await

关于创建Dart的更多实战技巧与最佳实践可学习《基于Flutter1.x开发携程网App

Last updated

Was this helpful?