zoukankan      html  css  js  c++  java
  • 学习笔记:flutter项目搭建(mac版)

    什么是flutter

    Flutter是谷歌的移动UI框架,可以快速在iOS和Android上构建高质量的原生用户界面。 Flutter可以与现有的代码一起工作。在全世界,Flutter正在被越来越多的开发者和组织使用,并且Flutter是完全免费、开源的。

    flutter具有以下几个优点

    • 快速开发(具有热加载功能,类似于webpack配置的devServer的热加载)
    • 富有表现力,漂亮的用户界面
    • 现代的,响应式框架(State类,通过调用setState,改变对应的值,widget就会重新渲染)
    • 访问本地功能和SDK
    • 统一的应用开发体验

    移动端解决方案的几个阶段

    1. webview在原生app中嵌入h5页面
    2. hybrid 通过JSBridge来做native与非native之间的桥梁(本质还是web模式)
    3. react-native 将view编译成原生的view从而达到良好的体验,但还是需要JSBridge做连接
    4. Flutter 吸收了前者的教训之后,在渲染技术上,选择了自己实现(GDI)

    reactive-native原理图

    flutter实现原理

    开始搭建flutter

    使用镜像

    flutter官方为中国开发者搭建了临时镜像,大家可以把下面的环境变量加到用户的环境变量中mac直接vim ~/.bash_profile修改即可,如果用了zsh 也可~/.zshrc,修改完source ~/.bash_profile即可

    export PUB_HOSTED_URL=https://pub.flutter-io.cn
    export FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn
    

    获取Flutter SDK

    传送门需要翻墙,或者直接去github下载安装包

    下载完解压,然后添加flutter到相关工具的path中export PATH=pwd/flutter/bin:$PATH

    注意pwd为你解压flutter安装包的路径

    运行flutter

    运行flutter doctor来查看还有什么东西没有安装,然后根据提示安装相应的东西即可

    创建一个flutter项目

    以上所有安装都完毕后可以再terminal通过flutter create 目录名来创建项目,然后执行open -a Simulator打开苹果手机模拟器

    安装下面的包来确保能进行ios模拟调试

    brew update
    brew install --HEAD libimobiledevice
    brew install ideviceinstaller ios-deploy cocoapods
    pod setup
    

    在你Flutter项目目录中通过 open ios/Runner.xcworkspace 打开默认的Xcode workspace.最后执行flutter run你的第一个flutter项目就跑起来了

    flutter推荐的编辑器有vscode以及Android studio安装对应的插件即可

    详细安装教程可以具体看flutter官网,本教程为自己的学习笔记,后面会另外开文如何使用flutter来进行开发

  • 相关阅读:
    Asp.Net Web API 2第一课——入门
    Servlet之ServletContext获取web上下文路径、全局参数、和Attribute(域)
    jsp 获取服务器ip 以及端口号
    对String值不可变的理解以及String类型的引用传递问题
    关于 SAXParseException Content is not allowed in Prolog (前言中不允许有内容)
    用tomcat插件 在Eclipse 中配置Tomcat项目
    docker保存日志文件到本地
    java split函数结尾空字符串被丢弃的问题
    byte类型的127+1=-128?
    java 中 Integer 传参方式的问题
  • 原文地址:https://www.cnblogs.com/songbw/p/11751928.html
Copyright © 2011-2022 走看看