前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >kotlin如何使用MVVM的开发模式

kotlin如何使用MVVM的开发模式

作者头像
大话swift
发布2020-04-14 21:49:30
2.1K0
发布2020-04-14 21:49:30
举报
文章被收录于专栏:大话swift大话swift

互联网开发模式经历了MVC、MVP。Android本身的开发模式为MVC,前些年MVP大行其道,这两年MVVM逐渐开始流行,最近准备用kotlin开发一个项目,顺便了解一下MVVM。

我采用的Android studio版本如下,因为大家会在软件版本上出问题,所以特意给大家贴出来我的版本

首先、建立一个新的Android工程,开发语言选择kotlin,如下图所示

其次、修改工程下的

C:\kotlin\live\app\build.gradle

apply plugin: 'com.android.application'apply plugin: 'kotlin-android'apply plugin: 'kotlin-android-extensions'apply plugin: 'kotlin-kapt'
android {    compileSdkVersion 29    buildToolsVersion "29.0.3"
    defaultConfig {        applicationId "com.xiangshike.live"        minSdkVersion 21        targetSdkVersion 29        versionCode 1        versionName "1.0"
        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"    }
    buildTypes {        release {            minifyEnabled false            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'        }    }    dataBinding {        enabled = true    }    androidExtensions {        experimental = true    }}
dependencies {    implementation fileTree(dir: 'libs', include: ['*.jar'])    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"    implementation 'androidx.appcompat:appcompat:1.1.0'    implementation 'androidx.core:core-ktx:1.2.0'    implementation 'androidx.constraintlayout:constraintlayout:1.1.3'    testImplementation 'junit:junit:4.12'    androidTestImplementation 'androidx.test.ext:junit:1.1.1'    androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'}

开启kotlin的支持

apply plugin: 'kotlin-android'apply plugin: 'kotlin-android-extensions'apply plugin: 'kotlin-kapt'

开启dataBinding的支持

    dataBinding {        enabled = true    }

新建一个基类BaseActivity

package com.xiangshike.live.base
import android.os.Bundleimport androidx.appcompat.app.AppCompatActivityimport androidx.databinding.DataBindingUtilimport androidx.databinding.ViewDataBinding
abstract class BaseActivity<DB : ViewDataBinding> : AppCompatActivity() {    lateinit var mDataBind: DB
    override fun onCreate(savedInstanceState: Bundle?) {        super.onCreate(savedInstanceState)        mDataBind = DataBindingUtil.setContentView<DB>(this, getLayoutId())        initData()        initView()    }
    abstract fun getLayoutId(): Int
    override fun onDestroy() {        super.onDestroy()        mDataBind.unbind()    }
    abstract fun initData()    abstract fun initView()}

建立一个模型

package com.xiangshike.live.model
data class User(val name: String)

建立MainActivity继承BaseActivity

package com.xiangshike.live
import android.text.Editableimport android.text.TextWatcherimport com.xiangshike.live.base.BaseActivityimport com.xiangshike.live.databinding.ActivityMainBindingimport com.xiangshike.live.model.Userimport kotlinx.android.synthetic.main.activity_main.*
class MainActivity : BaseActivity<ActivityMainBinding>() {    private var user = User("hanyun")    override fun getLayoutId(): Int = R.layout.activity_main    override fun initData() {        mDataBind.user = user    }
    override fun initView() {        editText.addTextChangedListener(object : TextWatcher {            override fun afterTextChanged(s: Editable?) {                mDataBind.user = user.copy(name = editText.text.toString())            }
            override fun beforeTextChanged(s: CharSequence?, start: Int, count: Int, after: Int) {            }
            override fun onTextChanged(s: CharSequence?, start: Int, before: Int, count: Int) {            }        })    }}

在这里要强调一下 BaseActivity这里的ActivityMainBinding的写法,然后编译一下导入包

视图的名称转换为每个单词的首字母大写+Binding,例如activity_main.xml=>ActivityMainBinding

视图activity_main.xml

<?xml version="1.0" encoding="utf-8"?><layout xmlns:android="http://schemas.android.com/apk/res/android">
    <data>
        <variable            name="user"            type="com.xiangshike.live.model.User" />    </data>
    <LinearLayout        android:layout_width="match_parent"        android:layout_height="match_parent"        android:orientation="vertical">
        <TextView            android:id="@+id/tv"            android:layout_width="match_parent"            android:layout_height="wrap_content"            android:text="@{user.name}" />
        <EditText            android:id="@+id/editText"            android:layout_width="match_parent"            android:layout_height="wrap_content" />
    </LinearLayout>

</layout>

其中,这里定义的变量名称user和MainActivity中mDataBind.user一致

        <variable            name="user"            type="com.xiangshike.live.model.User" />

这里的@{user.name}表示给模板赋值

        <TextView            android:id="@+id/tv"            android:layout_width="match_parent"            android:layout_height="wrap_content"            android:text="@{user.name}" />

最终的项目结构如下图

当我们修改了EditText的内容,TextView的内容也跟着改变了,从而实现数据绑定。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-04-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 大话swift 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 首先、建立一个新的Android工程,开发语言选择kotlin,如下图所示
  • 其次、修改工程下的
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档