一个简单的 Android 版本目录(Version catalog)实现指南

一个简单的 Android 版本目录实现指南


使用 TOML 格式
在本文中,我们将探讨版本目录以及如何实现它。

版本目录

Gradle 版本目录使您能够以可扩展的方式添加和维护依赖项和插件。因此,不必在各个构建文件中硬编码依赖项名称和版本,而是在目录中定义它们,并在所有模块中使用。

实现

要实现版本目录,我们可以在 settings.gradle 文件的 dependencyResolutionManagement 块中定义目录(查看此链接以了解更多详细信息),但我们将使用 TOML 格式来实现它…

https://docs.gradle.org/current/userguide/platforms.html

1- 创建一个版本目录文件

在根项目的 gradle 文件夹中,创建一个名为 libs.versions.toml 的文件。Gradle 默认在 libs.versions.toml 文件中查找目录,因此建议使用这个默认名称。

2- 定义您的版本、库和插件…

libs.versions.toml 中,我们可以定义我们的表…"

[versions]
kotlin = "1.8.10"
compose = '1.4.0'
material3 = '1.1.0-rc01'
...

[libraries]
compose-ui = { module = "androidx.compose.ui:ui", version.ref = "compose" }
compose-material3 = { module = "androidx.compose.material3:material3", version.ref = "material3" }
...

[plugins]
kotlin-android = { id = "org.jetbrains.kotlin.android", version.ref = "kotlin" }
...

基本上,[versions][libraries] 是一组键/值对(如 kotlin = "1.8.10")的集合,称为 Tables…

https://toml.io/en/v1.0.0#table

这些表将从所有构建文件的libs.table.key处访问,因此我们稍后将在构建文件中使用它们。

请注意,我们使用了版本引用(version.ref = "xxx")而不是硬编码版本。这样可以使我们的版本可重复使用 😃

注意:您可以使用分隔符,例如 -、_、.,Gradle 将它们归一化为 .,并允许您创建子部分。因此,compose-ui 将成为 compose.ui

3- 定义 bundles(可选)

优化的做法是声明依赖束,这是常用在一起的“依赖项组”。例如…

[bundles]
compose = [
    "compose-ui",
    "compose-material3"
]

4- 最后,在您的模块中使用它们 🤩

同步项目,嘿!您现在拥有了一切,可以轻松地使用类型安全的自动完成来定义依赖项… ,

plugins {
    alias libs.plugins.kotlin.android
    ...
}

dependencies {
    // compose
    implementation libs.compose.ui
    implementation libs.compose.material3

    // or you can use bundles
    implementation libs.bundles.compose
}

实际上就是这样 😃 现在您只需同步项目,解决 Gradle 抛出的数千个错误,然后就可以开始了

以下是一些有用的注意事项…

  • 1- 您可以不使用库的完整 ID…,
compose-ui = { module = "androidx.compose.ui:ui", ...}

而是分开定义库的组和名称…,

androidx-ktx = { group = "androidx.core", name = "core-ktx", ... }
  • 2- 通常,版本名称使用驼峰命名(例如,hiltCompose),而库、捆绑包和插件使用短横线命名(例如,androidx-ktx)。

  • 3- 在我们的 TOML 文件中声明的版本也可以通过类型安全的访问器访问,使它们可以用于更多用例,而不仅仅是依赖版本。例如,如果您正在使用 compose… "

composeOptions {
    kotlinCompilerExtensionVersion libs.versions.compose.get()
}

版本目录(Version catalog)的优势

  • 1- 使用类型安全的自动完成轻松添加依赖项。
  • 2- 所有依赖项都在一个地方进行管理,并对所有模块可见。
  • 3- 集中式版本控制。
  • 4- 捆绑包功能令人惊叹

缺点

  • 1- 没有依赖项更新建议。(但您可以使用此插件来帮助您保持库的最新状态)
  • 2- 迁移项目可能会比较繁琐(使用 Copilot 或向懂行的人寻求帮助吧)。

参考链接

https://github.com/infoilyasipek/satellite/commit/f516054ae393eca2cf1c8bdd58735aa1819aabbc
https://docs.gradle.org/current/userguide/platforms.html
https://developer.android.com/build/migrate-to-catalogs#groovy
https://proandroiddev.com/better-dependencies-management-using-buildsrc-kotlin-dsl-eda31cdb81bf

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
1. 首先在 layout 目录下新建一个布局文件,例如 list_item_layout.xml,用来定义 ListView 中每个 item 的样式。 2. 在 activity 中声明一个 ListView 对象,例如: ```java ListView listView = findViewById(R.id.list_view); ``` 3. 创建一个 ArrayList,用于存储 ListView 中的数据,例如: ```java ArrayList<String> dataList = new ArrayList<>(); dataList.add("Item 1"); dataList.add("Item 2"); dataList.add("Item 3"); ``` 4. 创建一个 ArrayAdapter 对象,用于将数据与 ListView 关联起来,例如: ```java ArrayAdapter<String> adapter = new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, dataList); ``` 其中,第一个参数是上下文 Context,第二个参数是 ListView item 的布局文件,第三个参数是数据源。 5. 将 ArrayAdapter 对象设置给 ListView,即: ```java listView.setAdapter(adapter); ``` 6. 完整代码示例: activity_main.xml: ```xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <ListView android:id="@+id/list_view" android:layout_width="match_parent" android:layout_height="wrap_content" /> </LinearLayout> ``` list_item_layout.xml: ```xml <?xml version="1.0" encoding="utf-8"?> <TextView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="16dp" /> ``` MainActivity.java: ```java public class MainActivity extends AppCompatActivity { private ListView listView; private ArrayList<String> dataList; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); listView = findViewById(R.id.list_view); dataList = new ArrayList<>(); dataList.add("Item 1"); dataList.add("Item 2"); dataList.add("Item 3"); ArrayAdapter<String> adapter = new ArrayAdapter<>(this, R.layout.list_item_layout, dataList); listView.setAdapter(adapter); } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Calvin880828

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值