V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
smile561607154
V2EX  ›  Flutter

Flutter Web 环境搭建

  •  
  •   smile561607154 · 2019-06-01 15:01:25 +08:00 · 7286 次点击
    这是一个创建于 2005 天前的主题,其中的信息可能已经有所发展或是发生改变。

    自从谷歌 I/O2019 发布Flutter web版本之后,有好多开发者尝试搭建环境,我也不例外,先前在公司电脑上搭建过一次,只是没有总结出教程,趁着周末在家无聊,再次在家里电脑搭建环境,由于官方文档中推荐是 Visual Studio Code 创建的项目,所以我就顺便研究了完全用命令行创建 web 项目。

    本文在 Mac 环境下完成,windows 环境大同小异,可作为参考。

    官方英文文档:https://github.com/flutter/flutter_web

    To use the Flutter SDK with the flutter_web preview make sure you have upgraded Flutter to at least v1.5.4 by running flutter upgrade from your machine. 在使用 flutter_web 预览版之前,要保证电脑中安装的 Flutter 版本是大于 1.5.4。

    以下是我机器的 flutter doctor 信息:

    Doctor summary (to see all details, run flutter doctor -v):
    [✓] Flutter (Channel stable, v1.5.4-hotfix.2, on Mac OS X 10.14.5 18F132, locale zh-Hans-CN)
    [✓] Android toolchain - develop for Android devices (Android SDK version 28.0.3)
    [✓] iOS toolchain - develop for iOS devices (Xcode 10.2.1)
    [✓] Android Studio (version 3.4)
    [✓] VS Code (version 1.34.0)
    [✓] Connected device (1 available)
    • No issues found!
    

    搭建步骤

    1、从 github 上面把 flutter_web 项目克隆到本地

    git clone https://github.com/flutter/flutter_web.git 存放目录随意,不过建议存放目录跟 flutter sdk 同级,日后更新维护好找

    2、安装 flutter_web 的编译工具 webdev

    flutter pub global activate webdev
    

    安装过程可能出现如下信息,此为网友在 windows 上配置时出现的

    Resolving dependencies …
    It looks like pub.dartlang.org is having some trouble
    Pub will wait for a while before trying to connect again.
    Got socket error trying to find package webdev at https://pub.dartlang.org.
    pub finished with exit code 69
    

    此问题我没碰到过,如果出现上诉问题是因为网络问题,建议多尝试几次。

    如果出现如下信息,则安装成功

    Precompiling executables …
    Precompiled webdev:webdev.
    Installed executable webdev.
    Activated webdev 2.0.6
    

    上述信息中可能有一个 Warning 提示需要配置环境变量,按提示配置环境变量即可

    可以尝试执行命令

    flutter pub global run webdev
    

    到此环境搭建成功了。

    3、创建和启动项目

    3.1 使用现有项目

    flutter_web 目录下有 examples 几个 demo 项目,比如:hello_world

    cd <flutter_web 目录>/examples/hello_world
    

    执行

    flutter pub upgrade
    或
    flutter pub get
    

    如果出现

    RandyWeideMacBook-Pro:hello_world wei$ flutter pub get
    ! flutter_web 0.0.0 from path ../../packages/flutter_web                
    ! flutter_web_ui 0.0.0 from path ../../packages/flutter_web_ui          
    Running "flutter packages get" in hello_world...                   21.9s
    

    说明项目配置成功了,然后就是启动本地服务,官方的命令是:webdev serve 实际使用过程中这个命令并不对 需要使用

    flutter pub global run webdev serve
    

    出现以下信息就是成功了

    RandyWeideMacBook-Pro:hello_world wei$ flutter pub global run webdev serve
    [INFO] Building new asset graph completed, took 1.5s
    [INFO] Checking for unexpected pre-existing outputs. completed, took 1ms
    [INFO] Serving `web` on http://localhost:8080
    [INFO] Running build completed, took 18.3s
    [INFO] Caching finalized dependency graph completed, took 201ms
    [INFO] Succeeded after 18.5s with 556 outputs (3217 actions)
    [INFO] ------------------------------------------------------------------------
    

    然后就可以在浏览器使用信息中的地址 http://localhost:8080 访问到了。

    3.2 创建新项目

    官方给两种途径创建新项目 1 )使用 Visual Studio Code,具体配置 Flutter Dart 插件就不多说。使用命令面板 Flutter: New Web Project,就可以创建一个新项目了,等配置完成后,按 F5 或者 Debug -> Start Debugging,就可以启动服务并自动打开浏览器。

    2 )使用 IntelliJ,没有研究

    3 )使用 Android Studio,因为本身我是开发安卓的,习惯使用 Studio 进行开发。然而 studio 并不能创建一个普通的 dart 项目,或者 flutter web 项目,相信后期官方一定是能支持的。

    目前想使用 studio 写代码的,可以使用 Visual Studio Code,创建完项目完之后,再用 Android Studio 打开项目,也是可以的。

    不过对于没有安装 Visual Studio Code 的同学来说的话,还可以用命令行来创建项目。

    命令行创建 web 项目需要安装另一个工具

    flutter pub global activate stagehand
    

    跟安装 webdev 一样 安装成功后可以执行下面命令查看帮助

    flutter pub global run stagehand
    
    Stagehand will generate the given application type into the current directory.
    usage: stagehand <generator-name>
        --[no-]analytics    Opt out of anonymous usage and crash reporting.
    -h, --help              Help!
        --version           Display the version for stagehand.
        --author            The author name to use for file headers.
                            (defaults to "<your name>")
    
    Available generators:
      console-full        - A command-line application sample.
      flutter-web-preview - A simple Flutter Web app.
      package-simple      - A starting point for Dart libraries or applications.
      server-shelf        - A web server built using the shelf package.
      web-angular         - A web app with material design components.
      web-simple          - A web app that uses only core Dart libraries.
      web-stagexl         - A starting point for 2D animation and games.
    
    

    可以看到这个工具可以按照 7 种模版创建项目,我们使用的是 flutter-web-preview,其他模版有兴趣的可以自行研究。

    创建一个项目目录,然后

    cd 目录
    

    执行命令

    flutter pub global run stagehand flutter-web-preview
    

    一个 web 项目就创建完成了,可以使用 studio 打开项目,使用flutter pub get配置好完之后,可以进行正常的代码了。

    第 1 条附言  ·  2019-06-01 16:13:51 +08:00
    纠正一个地方:文中提示官方文档中可以使用 webdev serve 启动服务,而实现过程并不行,是因为我没有配置 dart sdk 到环境变量
    所有相关的命令行,只要配置了 dart sdk 的,都可以省略掉前面的 flutter,如下示例:
    ```
    //环境变量只配置了 flutter sdk 而没有配置 dart sdk
    flutter pub global run stagehand flutter-web-preview
    //环境变量已经配置了 dart sdk
    stagehand flutter-web-preview
    ```
    第 2 条附言  ·  2019-06-01 16:14:26 +08:00

    纠正一个地方:文中提示官方文档中可以使用webdev serve启动服务,而实现过程并不行,是因为我没有配置dart sdk到环境变量 所有相关的命令行,只要配置了dart sdk的,都可以省略掉前面的flutter,如下示例:

    //环境变量只配置了flutter sdk而没有配置dart sdk
    flutter pub global run stagehand flutter-web-preview
    //环境变量已经配置了dart sdk
    stagehand flutter-web-preview
    
    2 条回复    2019-06-03 17:24:13 +08:00
    echo314
        1
    echo314  
       2019-06-01 20:47:29 +08:00
    将***\flutter\bin\cache\dart-sdk\bin 添加到 path 就可以直接用 webdev serve 了。
    smile561607154
        2
    smile561607154  
    OP
       2019-06-03 17:24:13 +08:00
    @echo314 是个大佬。后来我也发现了。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3383 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 00:41 · PVG 08:41 · LAX 16:41 · JFK 19:41
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.