变量
// 指定具体类型
bool x = true;
int y = 2;
double z = 2.13;
// 用var定义变量,不用指定具体类型
var a = true;
var b = 2;
var c = 2.13;
final name = 'Tom';
const num = 200000;
基本类型
var name = 'Tom';
// 使用$来实现name参数传入
var student = 'name is:$name';
// 使用构造函数创建List对象,和java一样
var list = List<int>();
list.add(1);
// 创建不可变List
var list1 = const[1,2];
// for-in循环,这里用到Dart中的in关键字
var list2 = [1,2,3,4];
for (var i in list2) {
print(i);
}
void main() {
// 通过构造器创建Map
Map map = new Map();
map['a'] = 'Android';
map['b'] = 'Flutter';
map['c'] = 'IOS';
print(map);
// 通过复制的方式
Map map1 = Map.of(map);
print(map1);
// 直接声明来创建Map
Map map2 = {'a': 'Android', 'b': 'Flutter', 'c': 'IOS'};
print(map2);
}
方法
void main() {
// 方法赋值给myarea对象
var myarea = _area(2,3);
print(myarea);
print(area2(2));
print(area3(2, height: 1, judge: false));
}
num _area(num width, num height) {
return width * height;
}
// 使用@required来标注必须参数
num area1({@required num width, @required num height}) {
return width * height;
}
// 可选参数
num area2(num width, [num height]) {
if (height != null) {
return width * height;
}
return 0;
}
// 默认参数
num area3(num width, {num height = 1, bool judge = true}){
if (judge) {
return width * height;
}
return 0;
闭包
支持闭包,闭包能够访问外部方法内部的局部变量
void main() {
var foo = a();
foo ();
foo ();
foo ();
foo ();
}
// 定义闭包
a() {
int count = 0;
// 匿名函数
return (){
print(count++);
};
}
嵌套函数
// 外层函数
void showName(var name) {
// 函数中嵌套函数
void printName(var name) {
print("Hello name is: $name");
}
// 使嵌套函数生效
printName(name);
}
// 主函数调用
void main() {
showName("Tom");
}
操作符
1.空替换?? expr1 ?? expr2,如果expr1是non-null,返回其值。否则执行expr2并返回其结果;
2.条件成员访问?.P?.y = 4; 如果p是non-null,则设置y的值等于4;
3.类型判定操作符(as,is,is!);
4.级联操作,可以在同一个对象上连续调用多个函数以及访问成员变量;
// 条件操作符(特有的 ??)
var oldState ;
// 传统的写法
var newState = (oldState == null) ? oldState : 'not final';
// 使用??操作符
var newState1 = oldState ?? 'not final';
// 避空(特有的?.)
void main() {
Person person = new Person('Tom');
Person person1 = null ;
// person 非空,正常返回
print(person?.name);
// person1为空,正常返回null
print(person1?.name);
// peroson1为空,报异常
print(person1.name);
}
class Person {
final String name;
Person(this.name);
}
// 类型判定操作符(as,is,is!,):
void main() {
var person = new Person();
// 判断person是不是Person类型
if (person is! Person) {
print("person is not Person type");
}
if (person is Person) {
person.name = 'Tom';
print(person.name);
}
// 上面代码可以使用as简化,as是把操作符对象转化为特定的类型
(person as Person).name = 'Tom';
print(person.name);
// 上面两种写法有区别,第一种是如果是true就执行里面的内容,false就不执行;
// 第二种情况使用as会抛出一个异常
}
class Person {
var name;
}
// 级联操作
// 获取一个id为btn1的按钮对象
var btn = query('#btn1');
btn.text = '确定';
btn.classes.add('ButtonStyle');
btn.onClick.listen((s) => window.alert('ok'));
// 上面代码等价于
query('#btn1')
..text = '确定'
..classes.add('ButtonStyle')
..onClisk.listen((s) => window.alert('ok'));
异常
void main() {
try {
test();
} on RangeError catch (e) {
print(e);
} on Error catch (e) {
print(e);
} finally {
print('finally');
}
}
test() {
throw RangeError("下标越界");
}
类
main() {
var point = new Point();
point.run();
// 这里会执行P类中的run()
// 可以理解成优先级覆盖,子类>重用>父类
P p = new P();
p.run();
Q q = new Q();
q.run();
}
class Point {
void run() {
print("Point run...");
}
}
class Note {
void run() {
print("Note run...");
}
}
// 多继承
class P extends Point with Note {
void run() {
print("P run...");
}
}
class Q implements Point {
@override
void run() {
print("Q run...");
}
}
构造函数
void main() {
var person = new Person("张三", 18, "Wuhan");
var person1 = new Person.init("李四", 20, "Shanghai");
// setter
person.name = "张三丰";
// getter
print(person.name);
print(person);
print(person1);
}
class Person {
var name;
int age;
final String address;
@override
String toString() {
return "name:$name age:$age address:$address";
}
Person(name, age, this.address) {
this.name = name;
this.age = age;
print("这里是传统的构造函数");
}
// 语法糖形式,命名构造函数
Person(this.name, this.age, this.address){
print("这里是语法糖的构造函数");
}
Person.init(this.name, this.age, this.address) {
print("这里是命名构造函数");
}
断言
// 确保变量是非空值
assert(text != null);
// 确保值是小于100
assert(number < 100);
// 确保这是一个 https 地址
assert(urlString.startsWith('https'));
注:检查模式是进行类型检查,如果发现实际类型和声明或期望类型不匹配就报错;生产模式是不进行类型检查,忽略声明的类型信息,比如可以忽略assert语句。Dart默认是生产模式。
参考:
[Dart语法预览](http://dart.goodev.org/guides/language/language-tour)