为了账号安全,请及时绑定邮箱和手机立即绑定

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

2018.01.03 17:49 4769浏览

关于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》

点击查看更多内容

本文原创发布于慕课网 ,转载请注明出处,谢谢合作

19人点赞

若觉得本文不错,就分享一下吧!

评论

相关文章推荐

正在加载中
意见反馈 邀请有奖 帮助中心 APP下载
官方微信

举报

0/150
提交
取消