AndroidStudio - TOML

一、概念

versions声明依赖项和插件的版本,然后引用这些变量。
libraries声明依赖项的别名
bundles声明依赖项的组名
plugins声明插件
  • 属性名单词之间用连词符号(而不是驼峰命名法),调用起来每个连词符号通过点调用,这样方便分类命名。
  • 只有[libraries]节点中的属性名可以直接调用,其它节点调用起来是 libs.节点名.属性称(因此其它节点可以出现重名)。

二、单个依赖

原来

dependencies {
    implementation 'androidx.core:core-ktx:1.9.0'
}

现在

[versions]
demo = "1.9.0"
 
[libraries]
#写法一
demo-compiler1 = "com.example:demo-compiler:1.9.0"
#写法二(推荐)
demo-compiler2 = { module = "com.example:demo-compiler", version = "1.9.0" }
#写法三
demo-compiler3 = { module = "com.example:demo-compiler", version.ref = "demo" }
#写法四
demo-compiler4 = { group = "com.example", name = "demo-compiler", version = "1.9.0" }
#写法五
demo-compiler5 = { group = "com.example", name = "demo-compiler", version.ref = "demo" }
dependencies {
    implementation(libs.demo.compiler1)
}

三、群组

[libraries]
compose-lifecycle = { ... }
compose-activity = { ... }
compose-viewmodel = { ... }

[bundles]
compose = ["compose-lifecycle", "compose-activity", "compose-viewmodel"]
dependencies {
    implementation(libs.bundles.compose)
}

四、插件

原来

// 项目
plugins {
   id("com.android.application") version "7.4.1" apply false
}
 
// 模块
plugins {
   id("com.android.application")    //聚合写法
}
apply plugin: 'com.android.library'    //单个写法

现在

[versions]
androidGradlePlugin = "7.4.1"
 
[plugins]
android-application = { id = "com.android.application", version.ref = "androidGradlePlugin" }
// 项目
plugins {
   alias(libs.plugins.android.application) apply false
}
 
// 模块
plugins {
   alias(libs.plugins.android.application)    //聚合写法
}
apply plugin: libs.plugins.android.library    //单个写法

五、历史遗留问题

仅针对老项目,新版AndroidStudio默认就使用TOML。

5.1 文件创建

在项目上右键→New→File→Vewsion Catalogs,取名 libs,会自动加后缀 .version.toml(没有就直接创建文件取完整名称)。在 settings.gradle 中的 <dependencyResolutionManagement> 标签下使用 <versionCatalogs> 引入所创建的文件。

5.2 无法升级 AGP 问题

将 Project 的 build.gradle 中 application 和 library 还原成默认书写方式。

id 'com.android.application' version '8.3.0' apply false
id 'com.android.library' version '8.3.0' apply false

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值