继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

Kotlin扩展函数与高阶函数-实际应用

雷宇
关注TA
已关注
手记 10
粉丝 1.7万
获赞 251

关于kotlin扩展函数与高阶函数网上有很多相关的资料介绍包括官方文档上也有详细的说明。咱们就不再重复理论的介绍通过一个简单的应用场景来看看如何使用。

不通过继承或使用 Decorator 模式在已有类中添加新的方法来实现某一具体功能。

将函数作为参数或返回一个函数称为高阶函数。

当任意一个输入框为空时“注册”按钮为不可用状态。
图片描述

当所有输入框都不为空时“注册”按钮为可用状态。
图片描述

  • 首先需要监听所有输入框的输入变化
  • 其次需要判断所有输入框是否都不为空
  • 最后根据判断设置“注册”按钮状态

根据我们的分析按照传统方式我们需要同时给4个输入框添加TextWatcher并且每个都需要判断其它几个输入框是否为空再来设置按钮。

但是我们使用的是kotlin既然最终改变的是按钮的状态那我们就可以给按钮扩展一个方法来设置它的状态设置的依据通过扩展方法的参数传入高阶函数

fun Button.enable(et: EditText, method: () -> Boolean){
    val btn = this
    et.addTextChangedListener(object : TextWatcher{
        override fun afterTextChanged(s: Editable?) {
        }

        override fun beforeTextChanged(s: CharSequence?, start: Int, count: Int, after: Int) {
        }

        override fun onTextChanged(s: CharSequence?, start: Int, before: Int, count: Int) {
            btn.isEnabled = method()
        }
    })
}

以上代码

  • Button扩展了一个方法enable
  • 第一个参数EditText因为需要监听它的变化
  • 第二个参数是方法方法的作用就是判断是否所有输入框都不为空返回值是Boolean
  • 在EditText监听中动态设置按钮是否可用
    private fun isBtnEnable():Boolean{
        return mMobileEt.text.isNotEmpty() &&
                mVerifyCodeEt.text.isNotEmpty() &&
                mPwdEt.text.isNotEmpty()&&
                mConfirmPwdEt.text.isNotEmpty()
    }

以上代码当所有输入框都不为空时返回true否则返回false

    mRegisterBtn.enable(mMobileEt,{isBtnEnable()})
    mRegisterBtn.enable(mVerifyCodeEt,{isBtnEnable()})
    mRegisterBtn.enable(mPwdEt,{isBtnEnable()})
    mRegisterBtn.enable(mConfirmPwdEt,{isBtnEnable()})

以上代码在初始化的时候调用扩展方法使用Lambda传入方法参数。

合理的使用扩展方法可以极大程度地减少代码量并且逻辑也会很清晰在需要的地方配合高阶函数事半功倍。

这只是一个简单场景应用更多精彩《Kotlin打造完整电商APP》

打开App,阅读手记
20人推荐
发表评论
随时随地看视频慕课网APP

热门评论

不错不错,很清晰,就应该多发这种文章

18685544455856

查看全部评论