2024年安卓最全Flutter混合开发(一):Android项目集成Flutter模块详细指南(1),面试题集锦

最后

一线互联网Android面试题含详解(初级到高级专题)

这些题目是今年群友去腾讯、百度、小米、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。并且大多数都整理了答案,熟悉这些知识点会大大增加通过前两轮技术面试的几率

如果设置门槛,很多开发者朋友会因此错过这套高级架构资料,错过提升成为架构师的可能。这就失去了我们的初衷;让更多人都能通过高效高质量的学习,提升自己的技术和格局,升职加薪。

最后送给大家一句话,望共勉,永远不要放弃自己的梦想和追求;

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

//container为activity_main布局中的占位符FrameLayout

transaction.replace(R.id.container, Flutter.createFragment(“initialRoute”));

transaction.commit();

}

}

这样就将Flutter默认的首页加载到应用上了。

从上面两部分代码中我们可以看到都有一个 “initialRoute” 参数,这个参数是用来告诉Dart代码在Flutter视图中显示哪个小部件。下面我们就来修改module中的main.dart代码来加载我们自己的页面。

我们设置两个route,分别展示route1Widget,和route2Widget,当没有匹配的时候展示提醒文字。

import ‘package:flutter/material.dart’;

import ‘dart:ui’;

void main() => runApp(MyApp(

//通过window.defaultRouteName获取从native传递过来的参数,需要导入dart:ui包

initParams: window.defaultRouteName,

));

class MyApp extends StatelessWidget {

final String initParams;

MyApp({Key key, this.initParams}) : super(key: key);

@override

Widget build(BuildContext context) {

return MaterialApp(

title: ‘Flutter_Android混合开发’,

theme: ThemeData(

primarySwatch: Colors.blue,

),

home: HomePage(initParams: initParams),

);

}

}

class HomePage extends StatefulWidget {

final String initParams;

const HomePage({Key key, this.initParams}) : super(key: key);

@override

_HomePageState createState() => _HomePageState();

}

class _HomePageState extends State {

@override

Widget build(BuildContext context) {

return Scaffold(

body: Center(

child: _widgetRoute(widget.initParams),

),

);

}

}

///路由转发

Widget _widgetRoute(String route) {

switch (route) {

case “route1”:

return route1Widget();

case “route2”:

return route2Widget();

default:

return notFoundWidget();

}

}

Widget route1Widget() {

return Center(

child: Text(

“this is route1Widget”,

style: TextStyle(color: Colors.red, fontSize: 20),

),

);

}

Widget route2Widget() {

return Center(

child: Text(

“this is route2Widget”,

style: TextStyle(color: Colors.blue, fontSize: 20),

),

);

}

Widget notFoundWidget() {

return Center(

child: Text(

“未匹配到路由111”,

style: TextStyle(fontSize: 40),

),

);

}

我们现在将加载Flutter时的initialRoute参数替换为 “route1”,那页面将加载route1Widget,替换为 “route2”,将加载route2Widget。否则将展示notFoundWidget。当然我们可以直接传路由参数,但是因为这个参数本身是一个字符串,所以我们可以来搞事情。比如传递一个json串,那么是不是可以做很多事呢?这里我就不贴demo了,因为和上面的逻辑基本一样,大家可以去试试看。

热重启/重新加载

===========================================================================

大家在写纯Flutter应用的时候,知道是有热重启/重新加载功能的,但是在做混合开发的过程中,你会发现热重启/重新加载功能失效了。那么如何在混合开发中开启热重启/重新加载功能呢?

  • 首先接入我们的设备或者模拟器

  • 将我们的App关闭,退出后台,在terminal中运行 flutter attach命令

$ flutter attach

Waiting for a connection from Flutter on Android SDK built for x86…

此时就在等待设备的连接。这里要注意的是,如果电脑连接了多台设备需要使用 -d 命令来指定一台设备,参数为设备的id。

flutter attach -d ‘你的设备id’

  • 然后启动我们的应用会看到控制台输出:

Done.

Syncing files to device Android SDK built for x86… 1,393ms

🔥 To hot reload changes while running, press “r”. To hot restart (and rebuild state), press “R”.

An Observatory debugger and profiler on Android SDK built for x86 is available at: http://127.0.0.1:59354/zRsDBfpesrk=/

For a more detailed help message, press “h”. To detach, press “d”; to quit, press “q”.

这样就表示我们连接成功了。在输出的日志中也告诉了我们如何使用热重启/重新加载功能。

在Terminal中输入以下命令​:​

r : 热加载;

R : 热重启;

h : 获取帮助;

d : 断开连接;

q : 退出;

这里的的 d 和 q 的命令都有退出调试,区别在于 d 命令只是单纯的断开而 q 命令会将应用退到后台。

调试Dart代码

===========================================================================

同样在混合开发过程中我们如何调试dart代码呢?

  • 关闭我们的应用

  • 点击Android Studio工具栏上的Flutter Attach按钮(需要安装Flutter与Dart插件)

  • 启动我们的应用

接下来就可以像调试普通Flutter项目一样来调试混合开发模式下的Dart代码了。

总结

=====================================================================

以上就是如何在Android原生项目中接入Flutter模块的基础讲解,主要就是模块的创建、依赖、调用以及调试等等。其它的像iOS接入Flutter模块,Android项目和Flutter项目之间的通信以及iOS项目和Flutter之间的通信都将在之后的文章中进行讲解。因为写在一篇中篇幅太长,朋友们读起来也累。所以后续还会有至少三篇相关的文章和大家见面。

文章转载自思否

原文链接:https://segmentfault.com/a/1190000020939448

原文作者:李四爷

学习分享,共勉

==========================================================================

程序员是一个需要不断学习成长的岗位,特别是大前端,题外话,我在大厂工作5年的时间里,通过

语言: Java 、Kotlin 、JavaScript 、 Dart ;

框架: React Native 、Weex 、Spring 、Flutter ;

开发模型:MVC、MVP、MVVM 、DI、AOP 、Reactive

等等的学习,虽有个人兴趣,也有工作所迫,但在学习技术的路上,只要你在行业内就很难停下来。

而在学习路线上,包括我自己,很多人都会有 “是不是学多就不精了” 的疑问。确实,学的东西多了,不可能在工作中都能有所应用,而且每项技术的探索可能都会深浅不一,所以避免跟风学习是前提。

但是回归到 “精通” 这个词,在不学多的情况下,你又是否真的在学精呢? 每个人都有自己的路线和学习风格,而我对自己的定位,更多是在自己的技术栈内去拓展技能。

此前我指导过不少同行,但很少跟大家一起探讨,正好最近我花了一个多月的时间整理出来一份包括Flutter全方面的进阶学习资料,今天暂且开放给有需要的人,若有关于此方面可以转发+关注+点赞后领取,或者评论与我一起交流探讨。

Flutter学习手册

Flutter学习视频

Flutter项目实战

总结

Android架构学习进阶是一条漫长而艰苦的道路,不能靠一时激情,更不是熬几天几夜就能学好的,必须养成平时努力学习的习惯。所以:贵在坚持!

上面分享的字节跳动公司2020年的面试真题解析大全,笔者还把一线互联网企业主流面试技术要点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

就先写到这,码字不易,写的很片面不好之处敬请指出,如果觉得有参考价值的朋友也可以关注一下我

①「Android面试真题解析大全」PDF完整高清版+②「Android面试知识体系」学习思维导图压缩包阅读下载,最后觉得有帮助、有需要的朋友可以点个赞

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

系」学习思维导图压缩包阅读下载**,最后觉得有帮助、有需要的朋友可以点个赞

[外链图片转存中…(img-udnQbPjS-1715747348020)]

[外链图片转存中…(img-FOn9rL99-1715747348020)]

[外链图片转存中…(img-el9KEfO9-1715747348021)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值