Flutter开发之Dart必备基础知识

在本文中咱们主要对标JavaScript来说解Dart与JavaScript的异同,对JavaScript还不熟悉的小伙伴能够省略JavaScript部分,直接学习Flutter部分。php

dart-for-flutter

程序入口

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

// Dart
main() {
}
复制代码

练一练 DartPad编程

DartPad是Dart的一个线上playground,提供Dart线上playground还有:Online Dart Compilerjson

控制台输出

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

// JavaScript
console.log("Hello world!");
// Dart
print('Hello world!');
复制代码

练一练 DartPad安全

变量

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

建立和分配变量

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

在 Dart中, 变量必须是明确的 类型或系统可以解析的类型。异步

// JavaScript
var name = "JavaScript";
// Dart
String name = 'dart'; // Explicitly typed as a string.
var otherName = 'Dart'; // Inferred string.
// Both are acceptable in Dart.
复制代码

练一练 DartPadasync

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

默认值

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

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

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

// JavaScript
var name; // == undefined
// Dart
var name; // == null
int x; // == null
复制代码

尝试一下 DartPad

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

检查null或零

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

// JavaScript
var myNull = null;
if (!myNull) {
  console.log("null is treated as false");
}
var zero = 0;
if (!zero) {
  console.log("0 is treated as false");
}
复制代码

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

// Dart
var myNull = null;
if (myNull == null) {
  print('use "== null" to check null');
}
var zero = 0;
if (zero == 0) {
  print('use "== 0" to check zero');
}
复制代码

练一练 DartPad

前方高能

Dart null检查最佳实践

从Dart 1.12开始,null-aware运算符可用帮助咱们作null检查:

bool isConnected(a, b) {
  bool outConn = outgoing[a]?.contains(b) ?? false;
  bool inConn = incoming[a]?.contains(b) ?? false;
  return outConn || inConn;
}
复制代码

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

对于表达式:

outgoing[a]?.contains(b)
复制代码

若是outgoing为null或outgoing[a]为null或contains(b)的值为null,都会致使表达式为null。

你们看一下下面预计的执行结果:

print(null ?? false);
print(false ?? 11);
print(true ?? false);
复制代码

练一练

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

Functions

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

// JavaScript ES5
function fn() {
  return true;
}
// Dart
fn() {
  return true;
}
// can also be written as
bool fn() {
  return true;
}
复制代码

练一练DartPad

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

异步编程

Futures

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

// JavaScript
_getIPAddress = () => {
  const url="https://httpbin.org/ip";
  return fetch(url)
    .then(response => response.json())
    .then(responseJson => {
      console.log(responseJson.origin);
    })
    .catch(error => {
      console.error(error);
    });
};
// Dart
_getIPAddress() {
  final url = 'https://httpbin.org/ip';
  HttpRequest.request(url).then((value) {
      print(json.decode(value.responseText)['origin']);
  }).catchError((error) => print(error));
}
复制代码

练一练: DartPad

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

async 和 await

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

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

// JavaScript
async _getIPAddress() {
  const url="https://httpbin.org/ip";
  const response = await fetch(url);
  const json = await response.json();
  const data = await json.origin;
  console.log(data);
}
复制代码

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

// Dart
_getIPAddress() async {
  final url = 'https://httpbin.org/ip';
  var request = await HttpRequest.request(url);
  String ip = json.decode(request.responseText)['origin'];
  print(ip);
}
复制代码

练一练 DartPad

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

关于Dart必备基础知识的更多实战技巧与最佳实践可学习《基于Flutter1.x开发携程网App》

未完待续

参考

相关文章
相关标签/搜索