新鲜出炉的 MVVM 脚手架 —— KtArmor-MVVM,面试安卓系统架构

这篇具有很好参考价值的文章主要介绍了新鲜出炉的 MVVM 脚手架 —— KtArmor-MVVM,面试安卓系统架构。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

}

通过 @BindViewModel 注解viewModel 变量,KtArmor-MVVM 通过反射,自动创建 LoginViewModel实例, 并赋值给 viewModel 变量。直接使用即可!

@BaseUrl

@BaseUrl(API.BASE_URL) // 看这里!!
interface ApiService {
@POST(API.LOGIN)
suspend fun login(@Query(“username”) username: String,
@Query(“password”) password: String): BaseResponse
}

我们通常使用Retrofit 的时候,都会创建对应 Service 接口类, 通过在 Service 上 标识 @BaseUrl 注解,并传入 对应 baseUrl,KtArmor-MVVM 就会将 baseUrl “注入” 到 Retrfit 中。目前只是针对单个 baseUrl, 后续将考虑多个 baseUrl 动态切换的相关处理。

KtArmor-MVVM框架引入

注意!

  • 由于采用了Androidx, 所以如果不是Androidx的话, 引入会有兼容性问题(会报错!).
  • 版本: minSdkVersion 19

以下默认是Androidx 项目下引入

先在 build.gradle(Project:XXXX) 的 repositories 添加:

allprojects {
repositories {

maven { url “https://jitpack.io” }
}
}

然后在 build.gradle(Module:app) 的 dependencies 添加:

implementation ‘com.github.hyzhan43:KtArmor-MVVM:1.0.7’ //最新版本

快速上手

我们先从一个 简单登录功能来熟悉一下 KtArmor-MVVM 使用流程。

LoginActivity

class LoginActivity : AppCompatActivity(), IMvmActivity {

@BindViewModel
lateinit var viewModel: LoginViewModel

override fun getLayoutId(): Int = R.layout.activity_login

override fun initListener() {
mBtnLogin.setOnClickListener {
viewModel.login(mEtAccount.str(), mEtPassword.str())
}
}

override fun dataObserver() {
viewModel.loginData.observe(this, Observer {
toast(“登录成功”)
})
}
}

  • 1、新建一个 LoginActivity 类,并实现 IMvmActivity “接口”

  • 2、然后使用 @BindViewModel 绑定一个 ViewModel,KtArmor-MVVM 会自动注入赋值。

  • 3、getLayoutId()方法,返回一个 R.layout.activity_login (布局id)

  • 4、initListener()方法中设置 登录按钮事件 (mBtnLogin),通过 viewModel 来发起网络请求。

  • 5、然后 在dataObserver()监听回调的结果即可。

然后我们再来看看, VM 层如何实现,也就是 LoginViewModel。

LoginViewModel

class LoginViewModel : BaseViewModel() {

val loginData = MutableLiveData()

fun login(account: String, password: String) {

// 校验参数
if (TextUtils.isEmpty(account) || TextUtils.isEmpty(password)) {
showToast(R.string.account_or_password_empty)
return
}

// DSL 方式发起 网络请求
quickLaunch {

onStart { showLoading() }

request { repository.login(account, password) }

onSuccess { loginData.value = it }
}
}
}

  • 需创建 LoginViewModel类,继承BaseViewModel,并传入 LoginRepository,自动注入 LoginRepositoy 实例。
  • quickLaunch<XXX> 方法是使用 DSL 方式发起网络请求
  • repository login 方法真正发起网络请求
  • onSuccess() 方法 监听回调结果,并设置给 LoginData

最后,我们来看看 Repository 的处理。

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
新鲜出炉的 MVVM 脚手架 —— KtArmor-MVVM,面试安卓系统架构,2024年程序员学习,面试,android,职场和发展
新鲜出炉的 MVVM 脚手架 —— KtArmor-MVVM,面试安卓系统架构,2024年程序员学习,面试,android,职场和发展
新鲜出炉的 MVVM 脚手架 —— KtArmor-MVVM,面试安卓系统架构,2024年程序员学习,面试,android,职场和发展
新鲜出炉的 MVVM 脚手架 —— KtArmor-MVVM,面试安卓系统架构,2024年程序员学习,面试,android,职场和发展
新鲜出炉的 MVVM 脚手架 —— KtArmor-MVVM,面试安卓系统架构,2024年程序员学习,面试,android,职场和发展
新鲜出炉的 MVVM 脚手架 —— KtArmor-MVVM,面试安卓系统架构,2024年程序员学习,面试,android,职场和发展
新鲜出炉的 MVVM 脚手架 —— KtArmor-MVVM,面试安卓系统架构,2024年程序员学习,面试,android,职场和发展

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
新鲜出炉的 MVVM 脚手架 —— KtArmor-MVVM,面试安卓系统架构,2024年程序员学习,面试,android,职场和发展

总结

作为一名从事Android的开发者,很多人最近都在和我吐槽Android是不是快要凉了?而在我看来这正是市场成熟的表现,所有的市场都是温水煮青蛙,永远会淘汰掉不愿意学习改变,安于现状的那批人,希望所有的人能在大浪淘沙中留下来,因为对于市场的逐渐成熟,平凡并不是我们唯一的答案!

新鲜出炉的 MVVM 脚手架 —— KtArmor-MVVM,面试安卓系统架构,2024年程序员学习,面试,android,职场和发展
新鲜出炉的 MVVM 脚手架 —— KtArmor-MVVM,面试安卓系统架构,2024年程序员学习,面试,android,职场和发展

远会淘汰掉不愿意学习改变,安于现状的那批人,希望所有的人能在大浪淘沙中留下来,因为对于市场的逐渐成熟,平凡并不是我们唯一的答案!

[外链图片转存中…(img-vmXZfSd0-1711874432523)]
[外链图片转存中…(img-nERTV93D-1711874432523)]

本文已被CODING开源项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》收录文章来源地址https://www.toymoban.com/news/detail-845998.html

到了这里,关于新鲜出炉的 MVVM 脚手架 —— KtArmor-MVVM,面试安卓系统架构的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • 脚手架开发流程详解

    创建npm项目 创建脚手架入口文件,最上方添加 配置package.json,添加bin属性 编写脚手架代码 将脚手架发布到npm 安装脚手架 使用脚手架 分包:将复杂的系统拆分成若干个模块 命令注册: 参数解析 options全称:–version、–help options简写:-V、-h 带params的options: --path /Users/sam/D

    2024年02月07日
    浏览(9)
  • 安装Node(脚手架)

    安装Node(脚手架)

    从官网直接下载安装即可,自带npm包管理工具。https://nodejs.org/en 安装之后在终端里查看查看node版本 安装webpack 安装vue-cli3.x以上 注意 要先在盘服中创建好文件夹,然后访问 创建好之后创建工程名字然后选择最后一个,最后一个是自定义项目 我就不选择Y了,我选的是N 创建项

    2024年02月11日
    浏览(18)
  • Vue 脚手架

    ├── node_modules ├── public │ ├── favicon.ico: 页签图标 │ └── index.html: 主页面 ├── src │ ├── assets: 存放静态资源 │ │ └── logo.png │ │── component: 存放组件 │ │ └── HelloWorld.vue │ │── App.vue: 汇总所有组件 │ │── main.js: 入口文件 ├── .gi

    2024年03月24日
    浏览(8)
  • 使用Vue脚手架

    使用Vue脚手架

    (193条消息) 第 3 章 使用 Vue 脚手架_qq_40832034的博客-CSDN博客 说明 1.Vue脚手架是Vue官方提供的标准化开发工具(开发平台) 2.最新的版本是4.x 3.文档Vue CLI脚手架(命令行接口) 具体步骤 1.如果下载缓慢请配置npm淘宝镜像 npm config set registry http://registry.npm.taobao.org 2.全局安装 @v

    2024年02月13日
    浏览(16)
  • 安装React脚手架

    在安装React脚手架之前,你需要决定使用哪个包管理工具。这里我们选择使用npm。运行下面的命令来安装React脚手架: 这个命令会在全局安装React脚手架工具create-react-app。 现在,你已经准备好创建一个新的React应用程序了。使用下面的命令来创建一个名为myreactapp的React应用程

    2024年02月09日
    浏览(34)
  • 如何搭建vue脚手架

    使用 create-vue 脚手架创建项目 create-vue参考地址:GitHub - vuejs/create-vue: 🛠️ The recommended way to start a Vite-powered Vue project 步骤: 执行创建命令 2.选择项目依赖类容 安装:项目开发需要的一些插件 必装: Vue Language Features (Volar)  vue3语法支持 TypeScript Vue Plugin (Volar)  vue3中更好的

    2023年04月14日
    浏览(15)
  • 使用Vue脚手架2

    使用Vue脚手架2

    ref属性 src/components/SchoolName.vue   src/App.vue   props配置项 src/App.vue src/components/StudentName.vue   注意:当props中与当前组件配置同名时, props中的配置优先级高于当前组件  mixin混入 1. 组件和混入对象含有同名选项 时,这些选项将以恰当的方式进行“合并”,在发生冲突时以 组件

    2024年02月12日
    浏览(8)
  • Vue(Vue脚手架)

    Vue(Vue脚手架)

    Vue官方提供脚手架平台选择最新版本: 可以相加兼容的标准化开发工具(开发平台) 禁止:最新的开发技术版本和比较旧版本的开发平台   Vue CLI 🛠️ Vue.js 开发的标准工具 https://cli.vuejs.org/zh/ c:cmmand l:line i:interface 命令行接口工具   在cmd中查看vue是否存在cli  全局安

    2024年02月01日
    浏览(10)
  • nuxt脚手架创建项目

    nuxt脚手架创建项目

    在初始化时遇到一个依赖找不到的问题,记录一下,如有遇到同样问题的小伙伴,希望能给你们一点指引。 从安装脚手架开始,首先 一:安装nuxt脚手架 1. C盘全局安装: npm i -g create-nuxt-app   安装后可create-nuxt-app -v查看 2. npx create-nuxt-app project-name 3. 会弹出选择安装项 选择项

    2024年02月13日
    浏览(8)
  • vue脚手架文件说明

    vue脚手架文件说明

    node_modules 都是下载的第三方包 public/index.html 浏览器运行的网页 src/main.js webpack打包的入口 src/APP.vue Vue页面入口 package.json 依赖包列表文件

    2024年02月15日
    浏览(14)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包