在Android开发中,Kotlin的扩展函数(Extension Functions)犹如一把神奇的瑞士军刀,它能显著提升代码简洁性和开发效率。以下是通过实战案例展示的扩展函数魔法手册:
一、扩展函数基础原理
// 给View添加渐显动画扩展
fun View.fadeIn(duration: Long = 300) {
animate().alpha(1f).setDuration(duration).start()
}
// 使用示例
myImageView.fadeIn(500) // 直接调用扩展函数
二、Android开发高频扩展场景
1. 视图操作优化
// 简化视图可见性控制
fun View.setVisible(visible: Boolean) {
visibility = if (visible) View.VISIBLE else View.GONE
}
// 防止重复点击(500ms冷却)
fun View.setOnSingleClickListener(block: () -> Unit) {
var lastClickTime = 0L
setOnClickListener {
if (System.currentTimeMillis() - lastClickTime > 500) {
lastClickTime = System.currentTimeMillis()
block()
}
}
}
2. 资源访问增强
// 颜色资源快捷获取
fun Context.color(@ColorRes resId: Int) = ContextCompat.getColor(this, resId)
// 字符串模板扩展
fun String.format(vararg args: Any) = if (args.isNotEmpty()) String.format(this, *args) else this
3. 日期时间处理
// 时间戳转格式化字符串
fun Long.toDateTimeString(pattern: String = "yyyy-MM-dd HH:mm"): String {
return SimpleDateFormat(pattern, Locale.getDefault()).format(Date(this))
}
// 使用示例
timestamp.toDateTimeString("MM/dd HH:mm")
4. 文件操作扩展
// 快速读取Assets文件
fun Context.readAssetsFile(fileName: String): String {
return assets.open(fileName).bufferedReader().use { it.readText() }
}
三、高阶扩展技巧
1. 链式调用增强
// 为AlertDialog.Builder添加快速完成方法
fun AlertDialog.Builder.quickShow(): AlertDialog {
return create().apply { show() }
}
// 链式调用
AlertDialog.Builder(this)
.setTitle("提示")
.setMessage("操作确认?")
.quickShow()
2. 与泛型结合
// 列表安全访问扩展
fun <T> List<T>.getOrNull(index: Int): T? {
return if (index in 0 until size) get(index) else null
}
// RecyclerView适配器安全访问
fun <T> ListAdapter<T, *>.getItemSafe(position: Int): T? {
return currentList.getOrNull(position)
}
3. 作用域函数整合
// SharedPreferences扩展(带自动commit)
fun SharedPreferences.edit(block: SharedPreferences.Editor.() -> Unit) {
edit().apply(block).apply()
}
// 使用示例
prefs.edit {
putString("token", newToken)
putLong("timestamp", System.currentTimeMillis())
}
四、性能与最佳实践
- 作用域控制:使用
@file:JvmName
限定扩展文件
@file:JvmName("ViewExtensions")
package com.example.extensions
fun View.hideKeyboard() { /* ... */ }
- 空安全扩展:为可空类型添加扩展
fun String?.orDefault(default: String = "") = this ?: default
- 扩展属性:添加计算属性
val TextView.trimmedText get() = text?.toString()?.trim() ?: ""
五、典型扩展库示例
// 网络请求状态处理扩展
fun View.bindNetworkState(
networkState: NetworkState,
onLoading: () -> Unit = { showLoading() },
onSuccess: () -> Unit = { showContent() },
onError: (String) -> Unit = { showError(it) }
) {
when (networkState) {
is NetworkState.Loading -> onLoading()
is NetworkState.Success -> onSuccess()
is NetworkState.Error -> onError(networkState.message)
}
}
通过合理使用扩展函数,开发者可以:
- 减少30%以上的模板代码
- 提升代码可读性和维护性
- 封装SDK的复杂接口
- 统一项目代码风格
关键技巧在于识别项目中重复出现的代码模式,将其转换为领域特定的扩展语言(DSL)。随着扩展库的积累,你会发现Android开发效率将得到质的飞跃。