美文网首页
信息绑定MVP

信息绑定MVP

作者: 比尔王BillWang | 来源:发表于2017-08-04 21:53 被阅读0次

社交性质的APP中,应该都有用户。用户信息展示地方的不同,会产生很多的样式。用户包含很多的信息、功能。用户需要展示头像、名字,有些需要点击以后跳转到用户详情,有些还可以关注用户,关注成功后其他页面需要刷新关注状态。但是样式的不同也使得展示的信息不同,有可能这个页面需要关注按钮,另一个地方却只需要一个头像。这就使得碎片化变得很严重,如果要增加有些逻辑就有可能会漏地方,并且数据设置也不够统一、布局需要多处findviewById。接下来我会通过自己的方法来尽量避免这些问题,如果有不对的地方请指正。

AUTH 声明了各种权限,比如(是否显示头像、用户名,点击后是否进入个人主页,是否实现关注功能)
M 暂时只是拿来放数据
V 实现findviewbyid,以及各种的setText setImage
P 实现onClickListener

实现的功能
1 设置用户的头像、名称;
2 在RecyclerView中点击后跳转到个人主页,在个人主页则不需要跳转;
3 实现关注用户的功能;
4 登录后隐藏自己个人主页的关注按钮;

class UserInfoAuth {
    public static final int ICON = 1 << 0;
    public static final int NAME = 1 << 1;
    public static final int CLICK = 1 << 2;
    public static final int FOLLOW = 1 << 3;
    public static final int FOLLOW_DISPEAR = 1 << 4;
}
class UserInfoM {
    private int auth;
    private UserBean;

    UserInfoM(int auth) {
        this.auth = auth;
    }

    public int getAuth() {
        return auth;
    }

    public void setUserBean(UserBean userBean) {
        this.userBean = userBean;
    }

    public UserBean getUserBean() {
        return userBean;
    }
}
class UserBean {
    private String name;
    private String icon;
    private boolean attention;

    public void setName(String name) {
        this.name = name;
    }

    public void getName() {
        return name;
    }

    public void setIcon(String icon) {
        this.icon = icon;
    }

    public String getIcon() {
        return icon;
    }

    public void setAttention(boolean attention) {
        this.attention = attention;
    }

    public boolean isAttention() {
        return attention;
    }
}
class UserInfoV {
    TextView nameTV, followTV;
    ImageView imageView;

    public void bindView(int auth, View rootView, OnclickListener listener) {
        if (checkAuth(UserInfoAuth.ICON)) {
            imageView = (ImageView) rootView.findViewById(R.id.image_view)
        }
        if (checkAuth(UserInfoAuth.NAME)) {
            nameTV = (ImageView) rootView.findViewById(R.id.name_TV)
        }
        if (checkAuth(UserInfoAuth.CLICK)) {
            rootView.setOnclickListener(listener);
        }
        if (checkAuth(UserInfoAuth.FOLLOW) {
            followTV.setOnClickListener(listener);
        }
    }

    public boolean checkAuth(int auth, int check) {
        return (auth & check) != 0;
    }

}
class UserInfoP implements {
    UserInfoM userInfoM;
    UserInfoV userInfoV;

    UserInfoP(int auth) {
        userInfoM = new UserInfoM(auth);
        userInfoV = new UserInfoV();
    }

    public void bindView(View rootView) {
        userInfoV.bindView(rootView, userInfoM.getAuth(), this);
    }

    public void setData(UserBean userBean) {
        userInfoV.setData(userBean);
    }

    @Override
    public void onClick(View v) {
        switch (v.getId()) {
            default:
                //gotoDetail
                break;
        }
    }
}

demo 地址
https://github.com/Billxxxx/BankSMSReader/tree/develop

相关文章

  • 信息绑定MVP

    社交性质的APP中,应该都有用户。用户信息展示地方的不同,会产生很多的样式。用户包含很多的信息、功能。用户需要展示...

  • JetPack--DataBinding

    MVP和MVVM中,ViewModel与Presenter很类似,只不过ViewModel和View层多了双向绑定...

  • dataBinding入门

    dataBinding翻译过来的意思就是数据绑定,跟MVVM模式相关,也有人说MVVM=mvp+dataBindi...

  • ios的MVVM(附代码)

    MVVM和MVP的最大不同在于前者是通过数据绑定的方式影响VC刷新的,数据绑定简单理解就是A=B+C,赋值之后,如...

  • MVVM

    上图是mvvm的数据流转图。 可以看出和mvp的数据流转图是一样的。和mvp的区别是,vm和v是双向绑定的,vm是...

  • Angular2双向绑定及变化检测

    前几天总结了MVC、MVP、MVVM设计模式,其中MVVM的核心机制就是双向绑定。React、Vue、Angula...

  • 又有MVP新写法了,这次我认为挺不错的

    EasyMvp 一个简单强大且灵活的MVP框架。 项目地址:EasyMvp 特点 一个 Activity 可以绑定...

  • 又有MVP新写法了,这次我认为挺不错的

    EasyMvp 一个简单强大且灵活的MVP框架。 项目地址:EasyMvp 特点 一个 Activity 可以绑定...

  • 第十九篇:iOS架构设计

    架构优化:高内聚,低耦合 MVC MVP :面向协议式编程 MWWM: 双向绑定(model和view可以相互控...

  • MVVM简析

    1、数据的双向绑定 MVVM模式不是四层,同MVP一样也是三层,但是我不同意MVVM是MVP的升级版,二者有相同的...

网友评论

      本文标题:信息绑定MVP

      本文链接:https://www.haomeiwen.com/subject/uspblxtx.html