expr1 ?? expr2
若是expr1非空,则返回其值; 不然,评估并返回expr2的值。json
冒号初始化是给数据成员分配内存空间时就进行初始化,就是说分配一个数据成员只要冒号后有此数据成员的赋值表达式(此表达式必须是括号赋值表达式),那么分配了内存空间后在进入函数体以前给数据成员赋值,就是说初始化这个数据成员此时函数体还未执行。网络
一、重定向到同一个类中的其余构造函数less
class Point { num x, y; // The main constructor for this class. Point(this.x, this.y); // Delegates to the main constructor. Point.alongXAxis(num x) : this(x, 0); }
二、调用非默认的超类构造函数ide
class Employee extends Person { // Person does not have a default constructor; // you must call super.fromJson(data). Employee.fromJson(Map data) : super.fromJson(data) { // “:"调用了他的超类Person中的命名构造函数 print('in Employee'); } }
三、还能够在构造函数主体运行以前初始化实例变量。初始值设定项用逗号分开。函数
import 'dart:math'; class Point { final num x; final num y; final num distanceFromOrigin; Point(x, y) : x = x, y = y, distanceFromOrigin = sqrt(x * x + y * y); } main() { var p = new Point(2, 3); print(p.distanceFromOrigin); }
StatelessWidget和StatefulWidgetui
StatefulWidgetthis
修饰的成员变量和成员方法是静态的惟一的 被全部实例共享 且由类自己直接调用编码
若是你不打算改变一个变量,可使用final和const,它们能够替代任何类型,必须在声明时初始化,且不能改变。code
区别:orm
const是编译器常量,它的值在编译期就能够肯定,final是运行时常量,它的初始值要到运行时才能肯定。
class Custom extends StatefulWidget { Custom({Key: key, this.title}) : super(key: key); // key ? final String title; @override _CustomState createState() => new _CustomState(); } class _CustomState extends State<Custom> { @override Widget build(BuildContext context) { // context: 当前控件(元素)的定位 print(’title: ${widget.title}’); // widget: StatefulWidget类(或者Custom类)的实例 } }
const定义的是编译时常量,只能用编译时常量来初始化
final定义的常量能够用变量来初始化
const list = const[1,2,3];//Ok const list = [1,2,3];//Error final list = [1,2,3];//Ok final list = const[1,2,3];//Ok final list = const[new DateTime.now(),2,3];//Error,const右边必须是常量
a 的数据类型能够随意改变,这种类型就是 dynamic
经常使用来修饰构造函数,将其变为工厂构造函数
工厂构造函数是一种构造函数,与普通构造函数不一样,工厂函数不会自动生成实例,而是经过代码来决定返回的实例对象.
dart:convert是dart提供用于在不一样数据表示之间进行转换的编码器和解码器,可以解析JSON和UTF-8。
用途:
网络请求返回(接口返回)时须要先将json数据(字符串)使用dart:convert转成Map,咱们就能经过Map转为dart对象了。
做用:1.子类和父类的变量,有语义上的冲突时,须要用super调用父类的变量(方法,变量)
2. 每一个子类的构造方法的第一句,都必须 显示或者隐式经过super调用父类的构造方法 3.隐式调用只能调用,无参的构造方法 4.若是父类没有无参的构造方法,那么必须使用super调用父类的构造方法 5.经过这样的机制保证了父类的构造方法先执行完毕,而后执行子类的构造方法 6.经过super 来访问父类的构造方法,执行的意义在于,对父类实例成员的初始化
this和super并不冲突,由于当前构造方法没有调用super()其余构造方法必然有,第一句必然是super
那这个构造方法调用了那个构造方法,也就是说这个构造方法的第一句也必然是执行父类的构造方法。
mixin MixinSuper on AbstractSuper {} // 声明了一种mixin,叫MixinSuper类,它继承了实现AbstractSuper类的ImplSuper类
等同于:
abstract class AbstractSuper {} class ImplSuper implements AbstractSuper {} class MixinSuper extends ImplSuper {} class Sub extends NormalSuper with MixinSuper {} // Sub类继承了NormalSuper类和MixinSuper类的合体区间
未完待续。。。