這篇文章將為大家詳細(xì)講解有關(guān)怎么利用Kotlin實(shí)現(xiàn)極簡(jiǎn)回調(diào),小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
站在用戶的角度思考問題,與客戶深入溝通,找到商水網(wǎng)站設(shè)計(jì)與商水網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、國(guó)際域名空間、網(wǎng)頁空間、企業(yè)郵箱。業(yè)務(wù)覆蓋商水地區(qū)。前言
在各種開發(fā)場(chǎng)景中,回調(diào)都有著廣泛的應(yīng)用,命名往往是各種Callback和Listener,其中在Android中接觸最早也最常用的可能就是View.OnClickListener了。
mBtn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Log.d("MM","Click"); } });
不過寫多了也有點(diǎn)煩惱,我只想打印一條日志,卻寫了這么多代碼。不過好在這個(gè)接口里面只包含一個(gè)方法,但換做一些包含方法數(shù)量比較多的回調(diào)就顯得比較臃腫了:
mEdit.addTextChangedListener(new TextWatcher() { @Override public void beforeTextChanged(CharSequence s, int start, int count, int after) { } @Override public void onTextChanged(CharSequence s, int start, int before, int count) { } @Override public void afterTextChanged(Editable s) { } });
如果你想優(yōu)化你的代碼,讓它們看起來更簡(jiǎn)潔優(yōu)雅,可以試試Kotlin的中的一些方法。
簡(jiǎn)化
先來看下Kotlin中的回調(diào):
mBtn.setOnClickListener(object :View.OnClickListener{ override fun onClick(v: View?) { println("Click") } })
好像一點(diǎn)也沒簡(jiǎn)化嘛,不過因?yàn)樵?Kotlin 里函數(shù)也是參數(shù)的一種,在 Java 中只包含一個(gè)方法的接口,在 Kotlin 中都可以使用 Lambda 表達(dá)式來達(dá)成一樣的效果。
mBtnCallback.setOnClickListener { println("Click") }
是不是簡(jiǎn)單很多了,但上面的用法僅適用于接口中只有一個(gè)方法的情況,如果存在多個(gè)方法的話,當(dāng)然也可以簡(jiǎn)化了:
mEdit.addTextChangedListener { beforeTextChanged { text, start, count, after -> println("beforeTextChanged") } onTextChanged { text, start, before, count -> println("onTextChanged") } afterTextChanged { text -> println("afterTextChanged") } }
也可以按需調(diào)用其中任意個(gè)方法:
mEdit.addTextChangedListener { onTextChanged { text, start, before, count -> println("onTextChanged") } }
不過此處的addTextChangedListener是一個(gè)擴(kuò)展函數(shù),需要我們來自己實(shí)現(xiàn):
inline fun TextView.addTextChangedListener(init: TextWatcherBridge.() -> Unit) = addTextChangedListener(TextWatcherBridge().apply(init)) class TextWatcherBridge : TextWatcher { private var beforeTextChanged: ((CharSequence?, Int, Int, Int) -> Unit)? = null private var onTextChanged: ((CharSequence?, Int, Int, Int) -> Unit)? = null private var afterTextChanged: ((Editable?) -> Unit)? = null override fun beforeTextChanged(s: CharSequence?, start: Int, count: Int, after: Int) { beforeTextChanged?.invoke(s, start, count, after) } override fun onTextChanged(s: CharSequence?, start: Int, before: Int, count: Int) { onTextChanged?.invoke(s, start, before, count) } override fun afterTextChanged(s: Editable?) { afterTextChanged?.invoke(s) } fun beforeTextChanged(listener: (CharSequence?, Int, Int, Int) -> Unit) { beforeTextChanged = listener } fun onTextChanged(listener: (CharSequence?, Int, Int, Int) -> Unit) { onTextChanged = listener } fun afterTextChanged(listener: (Editable?) -> Unit) { afterTextChanged = listener } }
原理就是實(shí)現(xiàn)一個(gè)擴(kuò)展函數(shù),把我們自己實(shí)現(xiàn)的TextWatcherBridge加入到回調(diào)中,因?yàn)镵otlin支持函數(shù)式編程,里面都是高階函數(shù)。為了減少性能損耗,擴(kuò)展函數(shù)聲明為內(nèi)聯(lián)函數(shù)。
關(guān)于“怎么利用Kotlin實(shí)現(xiàn)極簡(jiǎn)回調(diào)”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。