7.面向对象

dart是一门使用类和单继承的面向对象语言,所有的对象都是类的实例,所有的类都是Object的子类,换句话说就是万物皆对象

7.1.类与对象

void main() {
// 注意:new关键字可以省略
var p = new Person();
p.name = "xiaoqiang";
p.showName();
p.showAge();
} class Person {
String name;
int age;
void showName(){
print("名字是:${name}");
}
void showAge () {
print("年龄是:${age}");
}
}

注意1:可以使用final来创建一个只读的属性

void main() {
// 注意:new关键字可以省略
var p = new Person();
p.name = "xiaoqiang";
p.showName();
p.showAge();
p.gender = "女"; // 报错, gender定义的时候是不能修改的
} class Person {
String name;
int age;
final String gender="男";
void showName(){
print("名字是:${name}");
}
void showAge () {
print("年龄是:${age}");
}
}

注意2: 方法不能被重载

class Person {
String name;
int age;
final String gender="男";
void showName(){
print("名字是:${name}");
}
void showAge () {
print("年龄是:${age}");
}
void showName () { // 报错
print("名字是:${name}");
}
}

7.2.计算属性

计算属性从字面上可以理解为值是通过计算得来的

import 'dart:math';

void main() {
// 注意:new关键字可以省略
var p = new RrightTriangle();
// p.a = 3;
// p.b = 4;
// print(p.c);
p.c = 5;
print(p.a); } class RrightTriangle {
num a, b;
num get c {
return sqrt(a*a + b*b);
}
set c(value) {
a = sqrt(pow(value, 2) - 16);
}
}

7.3.构造方法

构造方法就是我们创建对象时调用的方法,如果没有自定义构造方法,则会调用默认的构造方法, 如果存在自定义的构造方法,则默认方法就无效,同时构造方法是不能重载的

void main() {
// 注意:new关键字可以省略
var p = new Person("xiaoqiang", 12, "男");
print(p.name); } class Person {
String name;
num age;
String gender;
Person(this.name, this.age, this.gender){
print(this.name);
print(this.age);
print(this.gender);
}
// 如果再定义一个Person方法就会报错
}

可以定义多个构造方法


void main() {
// 注意:new关键字可以省略
var p = new Person("xiaoqiang", 12, "男");
print(p.name);
// 创建对象的时候,可以使用fn构造方法
var p2 = new Person.fn("xiaohong", 12); } class Person {
String name;
num age;
String gender;
Person(name, age, gender){
this.name = name;
this.age = age;
this.gender = gender;
print(this.name);
print(this.age);
print(this.gender);
}
Person.fn(name, age) {
print(name);
print(age);
}
}

如果一个类是不可变的,这个时候我们需要使用const来声明构造方法,并且把所有变量都设置为final

import 'dart:math';

void main() {
// 注意:new关键字可以省略
var p = const Person("xiaoqiang", 12, "男");
p.name = "xxx"; // 报错 } class Person {
final String name;
final num age;
final String gender;
const Person(this.name, this.age, this.gender); }

螺钉课堂视频课程地址:http://edu.nodeing.com

dart快速入门教程 (7.1)的更多相关文章

  1. dart快速入门教程 (8)

    9.dart中的库 9.1.自定义库 自定义库我们在前面已经使用过了,把某些功能抽取到一个文件,使用的时候通过import引入即可 9.2.系统内置库 以math库为例: import "d ...

  2. dart快速入门教程 (7.4)

    7.12.多态 多态字面上理解就是多种状态,通俗的说,多态表现为父类定义一个方法不去实现,子类继承这个方法后实现父类的方法,这个方法有多种表现 // import 'person.dart'; voi ...

  3. dart快速入门教程 (7.3)

    7.4.抽离类为单独文件 新建一个文件,单独存放一个类,例如:Person类抽离到person.dart文件中 class Person { final String name; final num ...

  4. dart快速入门教程 (7.2)

    7.4.抽离类为单独文件 新建一个文件,单独存放一个类,例如:Person类抽离到person.dart文件中 class Person { final String name; final num ...

  5. dart快速入门教程 (2)

    2.变量和数据类型 2.1.变量和常量 变量通俗的说就是可以变化的量,作用就是用来存储数据,你可以把一个变量看作是一个水果篮,里面可以装苹果.梨.香蕉等,常量就是一个固定的值,和变量是相对的,变量可以 ...

  6. dart快速入门教程 (1)

    1.环境搭建 1.1.dart简介 Dart 是一种 易于学习. 易于扩展.并且可以部署到 任何地方 的 应用 编程 语言.Google 使用 Dart 来开发 大型应用.flutter使用dart语 ...

  7. dart快速入门教程 (6)

    6.内置操作方法和属性 6.1.数字类型 1.isEven判断是否是偶数 int n = 10; print(n.isEven); // true 2.isOdd判断是否是奇数 int n = 101 ...

  8. dart快速入门教程 (5)

    5.函数 5.1.函数定义 语法: 返回值类型 函数名(参数类型 参数1, 参数类型 参数2,...) { // 函数体 return '返回值' } 举例: void main() { print( ...

  9. dart快速入门教程 (4)

    4.流程控制 4.1.分支结构 1.if语句 void main() { int score = 80; if (score >= 90) { print('优秀'); } else if (s ...

随机推荐

  1. ArcCore重构-打通Can各层ID配置

    https://mp.weixin.qq.com/s/JX7VZwyMqk_9iVMm_N2pxA https://mp.weixin.qq.com/s/5Y8Dt9j1-NQmnjfYhE19dg ...

  2. jchdl - RTL Value Propagation

    https://mp.weixin.qq.com/s/2_0yQYdHlSQzPw7vX7NuHA     ​​ 因为建模方式的不同,RTL值的传播不同于GSL值的传播.   jchdl GSL模型的 ...

  3. 跟着阿里学JavaDay06——Java基础语法(四)

    一.方法 方法执行到return语句后,这个方法的执行就结束了,方法可以有返回值,但可以不用这个返回值.方法首先要定义,然后才能调用. public class TestMethod{ public ...

  4. Java实现 LeetCode 712 两个字符串的最小ASCII删除和(最长公共子串&&ASCII值最小)

    712. 两个字符串的最小ASCII删除和 给定两个字符串s1, s2,找到使两个字符串相等所需删除字符的ASCII值的最小和. 示例 1: 输入: s1 = "sea", s2 ...

  5. Java实现 LeetCode 543. 二叉树的直径(遍历树)

    543. 二叉树的直径 给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过也可能不穿过根结点. 示例 : 给定二叉树 1 / \ 2 3 / ...

  6. Java实现 LeetCode 451 根据字符出现频率排序

    451. 根据字符出现频率排序 给定一个字符串,请将字符串里的字符按照出现的频率降序排列. 示例 1: 输入: "tree" 输出: "eert" 解释: 'e ...

  7. Java实现预排序

    1 问题描述 在计算机科学中,预排序是一种很古老的思想.实际上,对于排序算法的兴趣很大程度上是因为这样一个事实:如果列表是有序的,许多关于列表的问题更容易求解.显然,对于包含了排序操作,这种算法的时间 ...

  8. java实现第五届蓝桥杯出栈次序

    出栈次序 X星球特别讲究秩序,所有道路都是单行线.一个甲壳虫车队,共16辆车,按照编号先后发车,夹在其它车流中,缓缓前行. 路边有个死胡同,只能容一辆车通过,是临时的检查站,如图[p1.png]所示. ...

  9. 记一次discuz修改首页图片路径问题

    1.找到图片路径拼装文件 首先打开根目录下的template目录找到首页文件 打开后找到图片列表的拼装位置 // 链接示例: <!--{eval $imagelistkey = getforum ...

  10. effictive c++

    c++条款 num 1:尽量以const enum inline替换#define 1)对于单纯常量,最好以const对象或enums替换#defines 2)对于形似函数的宏,最好改用inline函 ...