Flutter初探

Flutter简介

跨平台:RN 底层沿用的是原生iOS和安卓区别
Flutter:谷歌开发的,有自己的渲染引擎,保持Android和iOS保持一致性

Flutter小技巧

1.创建flutter工程

#创建flutter工程
#工程名不能用大写
flutter create flutter_demo
  • Flutter Package 只能用于 Dart 语言
  • Flutter Plugin 针对原生和Dart
  • Flutter Module 适用混合开发
  • pubspec.yaml 配置资源
  • 代码写在lib文件夹下
  • 主文件:main.dart

2.运行Flutter

模拟器运行
#运行 flutter run -d '模拟器名称'
flutter run -d 'iPhone X'
真机运行
#真机运行:配置证书
调试和热更新
  • Shift + R 重新运行
  • Shift + r 热更新
  • Release 版本后不支持热更新,有点儿像playground
  • flutter项目在Android环境下不能放在中文目录下,否则会编译报错或者用终端运行

热更新按钮,不用每次都运行工程

快捷键 Command + /

3.清除缓存

#清除flutter缓存 rm flutter缓存目录
rm /opt/flutter/bin/cache/lockfile

4.格式化代码

Command + option + L 格式化代码

5.代码块伸缩快捷键

Command + 减号 代码块伸缩

6.补充

  • final 不可变 var 可变
  • stl 无状态代码块快捷键
  • MaterialApp封装好一些列UI控件,类似iOS原生控件

7.源码

语言

dart语言

UI框架导入
import 'package:flutter/material.dart'; //类似UIKit
Flutter widget分类 Widget(小部件 类似UIView)
  • 有状态的 Stateful(多一个状态类) StatefulWidget
  • 无状态 Stateless(不可变) StatelessWidget
入口类函数
Simple
//入口函数(widget),采用声明式Ui
void main() {
  runApp(MyWidget());
}
其他写法
// main函数只有一行代码时,可以用 => 代替括号
void main() => runApp(App());```
定义Class及样式

传统定义Class

//一个widget就是一个类
class MyWidget extends StatelessWidget {
  //build 渲染方法或者构造函数
  @override
  Widget build(BuildContext context) {
    final _textStyle = TextStyle(
        color: Colors.red, fontSize: 40.0, fontWeight: FontWeight.bold);
    return Center(
      child: Text(
        'Hello,Widget,牛逼?',
        textDirection: TextDirection.ltr,
        style: _textStyle,
      ),
    );
  }

  Widget func() {
    return Text(
      '哈哈',
      textDirection: TextDirection.ltr,
    );
  }
}
MaterialApp使用
//dart语言
import 'package:flutter/material.dart'; //类似UIKit

//void main() {
//  runApp(MyWidget());
//}
// main函数只有一行代码时,可以用 => 代替括号
void main() => runApp(App());

class App extends StatelessWidget {
  //MaterialApp封装好一些列UI控件,类似iOS原生控件
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: Text('我是MaterialApp'),
        ), //导航条
        body: MyWidget(),
      ), //根控制器,debug标志
      theme: ThemeData(primaryColor: Colors.yellow),
    );
  }
}

//一个widget就是一个类
class MyWidget extends StatelessWidget {
  //build 渲染方法或者构造函数
  @override
  Widget build(BuildContext context) {
    final _textStyle = TextStyle(
        color: Colors.red, fontSize: 40.0, fontWeight: FontWeight.bold);
    return Center(
      child: Text(
        'Hello,Widget,牛逼?',
        textDirection: TextDirection.ltr,
         style: _textStyle,
      ),
    );
  }

  Widget func() {
    return Text(
      '哈哈',
      textDirection: TextDirection.ltr,
    );
  }
}
//material.app

效果图

Flutter效果图

转载于:https://www.cnblogs.com/StevenHuSir/p/Flutter-chu-tan.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值