Android——MVC、MVP、MVVM框架实现登录示例

简介: MVC描述缺点优点MVP效果图描述缺点优点代码解析视图效果图建立实体类建立实体类接口实现实体类接口设置P层建立交互接口数据绑定MVVM效果图描述代码解析导入dataBinding实体类建立viewmodelxml绑定数据视图与数据绑定


MVC



描述

自如其意,MVC分为三部分:M层、V层、C层。

M层:model层,主要用于逻辑处理。

V层:view层,主要指Activity、Dialog、Fragment,用于视图展示。

C层:controller层,用于视图层与数据层交互,此处由Activity充当。


缺点

视图层与数据层没有完成解耦,随着逻辑增多,会使Activity非常拥堵。


优点

比一个文件闯天下,稍微好一点


MVP



效果图

image.png

描述

自如其意,MVP分为三部分:M层、V层、P层。

M层:model层,主要用于逻辑处理。

V层:view层,主要指Activity、Dialog、Fragment,用于视图展示。

P层:presenter层,用于视图层与数据层交互。通过接口实现交互。


缺点

随着逻辑增多,用于实现视图层与数据层交互的接口数据就会增多

优点

数据层与视图层完成解耦


代码解析

视图效果图

image.png

建立实体类

public class User{
    private String UserName;
    private String PassWord;
    public User(String UserName,String PassWord){
        this.PassWord = PassWord;
        this.UserName = UserName;
    }
    public User(){
    }
    public String getUserName() {
        return UserName;
    }
    public void setUserName(String userName) {
        UserName = userName;
    }
    public String getPassWord() {
        return PassWord;
    }
    public void setPassWord(String passWord) {
        PassWord = passWord;
    }
}

建立实体类接口

public interface IUser {
    boolean LoginAccount(String userName,String passWord);
}

实现实体类接口

public class exeLogin implements IUser {
    private User user;
    @Override
    public boolean LoginAccount(String userName,String passWord) {
        if (userName.equals( "admin" ) && passWord.equals( "123456" )){
            user = new User(  );
            user.setUserName( userName );
            user.setPassWord( passWord );
            return true;
        }
        return false;
    }
}

设置P层

public class LoginPresenter {
    private exeLogin exeLogin;
    private IMain iMain;
    public LoginPresenter(IMain iMain){
        this.iMain = iMain;
        exeLogin = new exeLogin();
    }
    public void Login(){
        String userName = iMain.getUserName();
        String passWord = iMain.getPassWord();
        boolean isSuccess = exeLogin.LoginAccount( userName,passWord  );
        iMain.Login( isSuccess );
    }
}

建立交互接口

public interface IMain {
    String getUserName();
    String getPassWord();
    void Login(Boolean isLoginSuccess);
}

数据绑定

public class MainActivity extends AppCompatActivity implements IMain{
    private EditText userName,passWord;
    private Button btnLogin;
    private Context context = null;
    private LoginPresenter loginPresenter;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate( savedInstanceState );
        setContentView( R.layout.activity_main );
        InitView();
        Listener();
    }
    private void InitView(){
        userName = findViewById( R.id.username );
        passWord = findViewById( R.id.password );
        btnLogin = findViewById( R.id.login );
        loginPresenter = new LoginPresenter( this );
        if (context == null){
            context = MainActivity.this;
        }
    }
    private void Listener(){
        btnLogin.setOnClickListener( new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                loginPresenter.Login();
                Log.d( "TAG","click success" );
            }
        } );
    }
    @Override
    public String getUserName() {
        return userName.getText().toString().trim();
    }
    @Override
    public String getPassWord() {
        return passWord.getText().toString().trim();
    }
    @Override
    public void Login(Boolean isLoginSuccess) {
        if (isLoginSuccess){
            Toast.makeText( MainActivity.this,"Success",Toast.LENGTH_SHORT ).show();
            Log.d( "TAG","Success" );
        }else {
            Toast.makeText( MainActivity.this,"Fail",Toast.LENGTH_SHORT ).show();
            Log.d( "TAG","Fail" );
        }
    }
}

MVVM



效果图

image.png


描述

Model层:

数据处理

View层

实体

ViewModel:

实现视图与数据的交互,将二者分离,实现解耦


代码解析

导入dataBinding

image.png
dataBinding {
            enabled = true
        }

实体类

public class User extends BaseObservable {
    public String mUserName;
    public String mPassWord;
    public User(){
    }
    public User(String mUserName,String mPassWord){
        this.mUserName = mUserName;
        this.mPassWord = mPassWord;
    }
    @Bindable
    public String getmUserName() {
        return mUserName;
    }
    /**
     * @param mUserName */
    public void setmUserName(String mUserName) {
        this.mUserName = mUserName;
        notifyPropertyChanged( BR.mUserName );
    }
    @Bindable
    public String getmPassWord() {
        return mPassWord;
    }
    /**
     * @param mPassWord */
    public void setmPassWord(String mPassWord) {
        this.mPassWord = mPassWord;
        notifyPropertyChanged( BR.mPassWord );
    }
}

添加 @Bindable,作为xml绑定字段

 @Bindable
    public String getmUserName() {
        return mUserName;
    }

BR是一个自动生成的类,大致内容为将每一个字段添加ID,通过notifyPropertyChanged实现数据更新

/**
     * @param mUserName */
    public void setmUserName(String mUserName) {
        this.mUserName = mUserName;
        notifyPropertyChanged( BR.mUserName );
    }


建立viewmodel

public class ViewModel {
    private ActivityMainBinding binding;
    public User user;
    public ViewModel(ActivityMainBinding binding,User user){
        this.binding = binding;
        this.user = user;
    }
    public void Login(View view){
        if (user.getmUserName().equals( "admin" ) && user.getmPassWord().equals( "123456" )){
            Log.d( "TAG","success" );
        }else {
            Log.d( "TAG","fail" );
        }
        Log.d( "TAG",user.getmUserName()+"" );
        Log.d( "TAG",user.getmPassWord()+"" );
    }
}


xml绑定数据

注意视图绑定数据层字段时,一个等于=符号产生不同结果,如果没有等于,我在输入框输入的数据,实体类数据不会刷新,加上等号,完成数据双向绑定。

密码输入框中输入123456

android:text="@={viewmodel.user.mPassWord}"

image.png

密码输入框中输入123456,而打印出来是12345,并没有完成双向绑定

android:text="@{viewmodel.user.mPassWord}"

image.png

<?xml version="1.0" encoding="utf-8"?>
<layout
    xmlns:android="http://schemas.android.com/apk/res/android">
    <data>
        <variable
        name="user"
        type="com.franzliszt.mvvmtest.model.User" />
        <variable
            name="viewmodel"
            type="com.franzliszt.mvvmtest.viewmodel.ViewModel" />
    </data>
    <LinearLayout
        xmlns:app="http://schemas.android.com/apk/res-auto"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        >
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:paddingTop="40dp">
        </LinearLayout>
        <TextView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:paddingLeft="30dp"
            android:text="账号密码登录"
            android:textColor="#000000"
            android:textSize="30sp"
            android:layout_marginTop="20dp"/>
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal"
            android:layout_margin="20dp">
            <EditText
                android:id="@+id/username"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:hint="用户名"
                android:paddingLeft="10dp"
                android:singleLine="true"
                android:textColor="#ff000000"
                android:textSize="15sp"
                android:text="@={viewmodel.user.mUserName}"
                />
        </LinearLayout>
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_margin="20dp">
            <EditText
                android:id="@+id/password"
                android:layout_width="match_parent"
                android:layout_height="40dp"
                android:layout_marginTop="10dp"
                android:hint="密   码"
                android:paddingLeft="10dp"
                android:password="true"
                android:textColor="#ff000000"
                android:textSize="15sp"
                android:text="@={viewmodel.user.mPassWord}"
                />
        </LinearLayout>
        <Button
            android:id="@+id/login"
            android:layout_width="200dp"
            android:layout_height="wrap_content"
            android:layout_marginLeft="80dp"
            android:layout_marginTop="10dp"
            android:background="#1A73E8"
            android:text="登录"
            android:textColor="#ffffff"
            android:textSize="15sp"
            android:onClick="@{viewmodel.Login}"/>
    </LinearLayout>
</layout>


视图与数据绑定

初始化User类的数据, 完成视图与数据绑定

public class MainActivity extends AppCompatActivity {
    private ActivityMainBinding binding;
    private User user;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate( savedInstanceState );
        binding = DataBindingUtil.setContentView( this,R.layout.activity_main );
        user = new User( "admin","12345" );
        binding.setViewmodel( new ViewModel( binding,user ) );
    }
}

相关文章
|
1月前
|
设计模式 存储 前端开发
MVVM、MVC、MVP三种常见软件架构设计模式的区别
MVC、MVP 和 MVVM 是三种常见的软件架构设计模式,主要通过分离关注点的方式来组织代码结构,优化开发效率。
52 12
|
2月前
|
设计模式 前端开发 Android开发
Android应用开发中的MVP架构模式解析
【5月更文挑战第25天】本文深入探讨了在Android应用开发中广泛采用的一种设计模式——Model-View-Presenter (MVP)。文章首先概述了MVP架构的基本概念和组件,接着分析了它与传统MVC模式的区别,并详细阐述了如何在实际开发中实现MVP架构。最后,通过一个具体案例,展示了MVP架构如何提高代码的可维护性和可测试性,以及它给开发者带来的其他潜在好处。
|
19天前
|
开发工具 Android开发
技术经验分享:Android编译命令m、mm、mmm区别及工程搭建示例
技术经验分享:Android编译命令m、mm、mmm区别及工程搭建示例
15 0
|
1月前
|
前端开发 测试技术 API
探索安卓应用的架构演进:从MVC到MVVM
本篇文章将深入探讨安卓应用开发中的架构演进,特别关注从传统的MVC(Model-View-Controller)到现代流行的MVVM(Model-View-ViewModel)架构的转变。通过对比两种架构的设计理念、实现方式和实际应用案例,解析MVVM在提高代码可维护性和可测试性方面的优势。
25 0
|
2月前
|
前端开发 Android开发
Android架构组件JetPack之DataBinding玩转MVVM开发实战(四)
Android架构组件JetPack之DataBinding玩转MVVM开发实战(四)
Android架构组件JetPack之DataBinding玩转MVVM开发实战(四)
|
2月前
|
存储 前端开发 Java
Android应用开发中的MVP架构模式实践
【5月更文挑战第5天】随着移动应用开发的复杂性增加,传统的MVC(Model-View-Controller)架构在应对大型项目时显得笨重且不灵活。本文将探讨一种更适应现代Android应用开发的架构模式——MVP(Model-View-Presenter),并展示如何在Android项目中实现该模式以提升代码的可维护性和可测试性。通过对比分析MVP与传统MVC的差异,以及提供一个实际案例,读者将能深入了解MVP的优势和实施步骤。
|
2月前
|
前端开发 测试技术 数据处理
安卓开发中的MVP架构模式深度解析
【4月更文挑战第30天】在移动应用开发领域,模型-视图-呈现器(Model-View-Presenter, MVP)是一种广泛采用的架构模式。它旨在通过解耦组件间的直接交互来提高代码的可维护性和可测试性。本文将深入探讨MVP在安卓开发中的应用,揭示其如何促进代码的模块化,提升用户界面的响应性,并简化单元测试过程。我们将从理论概念出发,逐步过渡到实践案例,为读者提供一套行之有效的MVP实施策略。
|
2月前
|
XML 前端开发 测试技术
安卓架构模式:MVC、MVP、MVVM及更多
【4月更文挑战第13天】本文探讨了安卓应用开发中的常见架构模式,包括MVC、MVP和MVVM,以及VIPER和Clean Architecture。MVC分离关注点,易于理解,但安卓不直接支持。MVP通过呈现器实现更清晰的分层和便于单元测试。MVVM利用数据绑定简化UI逻辑,适合声明式编程。开发者应根据项目需求、团队技能和维护周期选择合适架构,随着工具和框架的进步,未来将提供更多模块化、可测试性和敏捷性的解决方案。
|
2月前
|
Android开发
Android 高通平台集成无源码apk示例
Android 高通平台集成无源码apk示例
41 0
|
2月前
|
前端开发 JavaScript
Vue中mvvm/mvc/mvp三者区别
Vue中mvvm/mvc/mvp三者区别