从 JS 到 Dart:语法基础

声明:var final const。支持自动推断类型,但类型一直固定。未初始化的值为 null

Final vs const: const 编译时确定,final 运行时确定

基本类型:num int double String bool List Set Map

  1. int.parse('1'); // 1 1.toString()
  2. 带变量的字符串:${expression}
  3. 字符串连接:"字符串1" "字符串2"
    "字符串3";
    用加号也行
  4. 多行字符串
    '''
    这是第一行字符串。
    这是第二行字符串。
    '''
  5. enum Color { red, green, blue } Color.blue Color.blue.index
    级联调用:a...b=1;...c.d() 等价于 a.b=1; a.c.d()
    算数运算符:/除 ~/除法取整
    类型运算符:as is is!
    条件运算符:x ?? y 等价于 x ? x : y
    List 类型:list.add('x') list.insert(2, 'x') list.remove('x') list.sort() list.sort((a, b) => a < b ? 1 : -1) list.indexOf('x') list.contains('x')
    new 是可选的 List a = new List(); ✅ List a = List();✅
    Set 类型:set.add('x') set.addAll(['x', 'y', 'z']) set.remove('x') set.clear() set.contains('x') for(var x in set)
    Map 类型:map["k1"]="v1" map.remove("k1") map.clear() map.length map.foreach((k, v) {})
    忽略参数定义顺序的函数传参:定义:void enableFlags({bool bold, bool hidden}) {} enableFlags(hidden: true, bold: false);
    可选参数:void fun(int a, [int b=1, int c=2]){}
    闭包函数:(a, b) {return a>b} 闭包函数可以做闭包。箭头函数:(a, b)=>a>b
    类:_x私有属性 this.y✅ y✅(在没有歧义的情况下) 参数初始化 Point(int x, int y) : this.x = x, this.y = y {} Point(this.x, this.y);
    命名构造方法(预制构造方法)Point.origin() {x = 0;y = 0;} new Point.origin()
    工厂模式构造方法:factory X(String type){if(type=='type1') return x;if(type=='type1') return y;}一般要搭配命名构造方法使用
    extends implements
    运算符重载 bool operator <(Point v) => x < v.x && y < v.y;
    mixin 实现多继承:被混入的类 mixin X {...} 继承 class A extends Y with X, Z {...}
    异常可以直接 throw "string" 或 throw Exception("xxx")
    捕获异常:try {...} on AException {...} on BException {...} on Exception catch (e) {...} catch (e) {...}
    重新抛出异常:rethrow
    Finally
    异步处理 Future=Promise async/await
    异步数据序列 Stream await for (数据类型 变量 in stream类型变量) {// 处理数据}
相关推荐
lbb 小魔仙3 分钟前
【HarmonyOS】DAY13:Flutter电商实战:从零开发注册页面(含密码验证、确认密码完整实现)
flutter·华为·harmonyos
一位搞嵌入式的 genius13 分钟前
从 URL 到渲染:JavaScript 性能优化全链路指南
开发语言·前端·javascript·性能优化
芭拉拉小魔仙13 分钟前
Vue 3 组合式 API 详解:告别 Mixins,拥抱函数式编程
前端·javascript·vue.js
别叫我->学废了->lol在线等13 分钟前
taiwindcss的一些用法
前端·javascript
晚霞的不甘22 分钟前
Flutter for OpenHarmony 豪华抽奖应用:从粒子背景到彩带动画的全栈实现
前端·学习·flutter·microsoft·前端框架
铅笔侠_小龙虾30 分钟前
浅谈 Vue & React & Flutter 框架
vue.js·flutter·react.js
前端摸鱼匠38 分钟前
Vue 3 的ref在响应式对象中:介绍ref在reactive对象中的自动解包
前端·javascript·vue.js·前端框架·ecmascript
Polaris_YJH42 分钟前
使用Vue3+Vite+Pinia+elementUI搭建初级企业级项目
前端·javascript·elementui·vue
日光倾44 分钟前
【Vue.js 入门笔记】 状态管理器Vuex
vue.js·笔记·flutter
Highcharts.js1 小时前
如何在构建音频图表中映射到数据?
javascript·信息可视化·音视频·开发文档·highcharts·数据映射