MVP不只是一个产出,还是一个过程,更是一种表达

MVP这个概念,更多时候是在描述一个静态产出物,具体的意思就不展开说了。

延伸阅读:

MVP是什么,不是什么

MVP的哲学底色

今天聊聊把MVP视为一个动态过程,背后意味着什么。

03e3fc1f1d58f4dec4d2d2c6170ff708.jpeg

人们在归纳、演绎这两个基础方法论之上,提出了“假说-演绎”方法之后,各个领域都有了应用。

2c6de68a86077bd804b6d53d32c128a2.png

如果用这个这个思路——

做产品就从一次性的有限游戏,变成不断螺旋上升的无限游戏。

做产品的逻辑就从追求证实、追求“对”,变成不断证伪、发现“错”,来逼近。

每一次作为产出物的MVP,是什么东西不重要,重要的是必须可以拿来和用户/市场互动,作为下一次产出的基石,以形成闭环。

乔布斯说——不要做用户调研,因为用户也不知道自己需要什么,直到你把产品拿到用户的面前,他才会告诉你,这不是我想要的——其实,这就是乔布斯的调研方式。用MVP和用户互动,发现“错”,再迭代。

这种做法,背后最大的挑战,我渐渐觉得,可能是自我认知方面的,要减小Ego、承认自己的无知、勇于接受失败、享受自我打脸……

给一个案例:我们如何造红色敞篷跑车

理解了以上,就可以理解,为什么每一次MVP的“低成本”是重要且必要的了。

因为每个产品一旦推向市场,就要准备好被批判、被扬弃,就要做下一个更好产品的垫脚石。

5fdbb27ab3db9409b0df089a267852ca.jpeg

继续,做产品的过程,就是提出一系列假设,用各种维度的MVP去验证各种假设,再修正假设、迭代产品的过程。

所以,我觉得MVP未必要完整,例如一个3D打印模型也可以验证外观设计的部分假设、一次营销活动也可以验证某些会员权益的假设。

一个产品,就是围绕着, 创造它的团队信念中的一系列假设构建而成,MVP则是一种表达。

所以才会有人说,优秀的产品体现了创造者的价值观,即所谓的一个不那么准确的说法“创造需求 > 满足需求”。

“创造者的表达”和“对用户需求的满足”冲突么?

“用心听,不照做”这个心法可以回答这个问题。“用心听”是面向过去、面向用户、面向问题,“不照做”是面向未来、面向新的方案,更好地满足用户,在产品中融入自我,表达自我,当然,要产品好,做产品的人就得“好”。

亦如我说过的“对世界不冷漠,对他人不迎合,对自己不放纵”。

这种自我表达,又绝对不霸道,保持谦卑,心态开放,随时否定自己。

当某些核心假设被推翻,比如“目标用户是XXX”,我们的产品就很可能没法通过渐进式的迭代来继续满足市场,而需要推出所谓的第二曲线,或者简言之——另一个产品。

而对于一些非核心假设的修正,可以很实用主义,当我们发现“所有的天鹅都是白的”被一只澳洲的黑天鹅打破之时,也不用整体放弃这个假设,而是可以把假设修正为“除了澳洲的天鹅都是白的”,再到“除了澳洲和华为松山湖园区里的天鹅都是白的”,如下图……

a5d4ca2733cdb83a6ec58d207e8a8dbc.jpeg

直到修修补补不够了,就重构整个假设体系。

Always MVP,没有完成的产品。

以上。

PS:本文思考的一些思想来源——波普尔的证伪主义、托马斯·库恩的范式转移、拉卡托斯的精致证伪主义

_________

苏杰(iamsujie),产品创新顾问,《人人都是产品经理》系列4本书的作者,前阿里8年产品经理,集团产品大学负责人,良仓孵化器创始合伙人。如需产品经理/产品思维/产品创新相关领域的培训咨询服务,欢迎联系这个微信(13758212411)。

阅读终点,创作起航,您可以撰写心得或摘录文章要点写篇博文。去创作
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,下面我来给你讲解一下在Android Studio中使用MVP开发模式实现登录和注册功能的步骤: 1. 首先,我们需要创建一个MVP的架构,其中包含View、Presenter和Model。 2. 创建一个登录和注册的Activity,并且实现View接口,同时在Activity中创建Presenter对象。 3. 在Presenter中实现登录和注册的业务逻辑,并且通过接口回调将结果返回给View。 4. 创建一个Model类,用于处理与服务器的交互,包括登录和注册的网络请求。 5. 在View中实现用户交互界面,并且通过Presenter调用登录和注册的方法。 6. 最后,在Manifest文件中添加相应的Activity和权限。 下面是一个简单的示例代码: 1. 创建View接口 ```java public interface LoginView { void onLoginResult(Boolean result, int code); void onRegisterResult(Boolean result, int code); } ``` 2. 创建Presenter类 ```java public class LoginPresenter implements LoginContract.Presenter, OnLoginFinishedListener, OnRegisterFinishedListener { private LoginContract.View loginView; private LoginModel loginModel; public LoginPresenter(LoginContract.View loginView) { this.loginView = loginView; loginModel = new LoginModel(); } @Override public void validateCredentials(String username, String password) { if (loginView != null) { loginView.showProgress(); } loginModel.login(username, password, this); } @Override public void register(String username, String password) { if (loginView != null) { loginView.showProgress(); } loginModel.register(username, password, this); } @Override public void onDestroy() { loginView = null; } @Override public void onLoginSuccess() { if (loginView != null) { loginView.hideProgress(); loginView.onLoginResult(true, 200); } } @Override public void onLoginError() { if (loginView != null) { loginView.hideProgress(); loginView.onLoginResult(false, 401); } } @Override public void onRegisterSuccess() { if (loginView != null) { loginView.hideProgress(); loginView.onRegisterResult(true, 200); } } @Override public void onRegisterError() { if (loginView != null) { loginView.hideProgress(); loginView.onRegisterResult(false, 401); } } } ``` 3. 创建Model类 ```java public class LoginModel implements LoginContract.Model { @Override public void login(String username, String password, OnLoginFinishedListener listener) { // 发送登录请求 // 如果登录成功,调用listener.onLoginSuccess() // 如果登录失败,调用listener.onLoginError() } @Override public void register(String username, String password, OnRegisterFinishedListener listener) { // 发送注册请求 // 如果注册成功,调用listener.onRegisterSuccess() // 如果注册失败,调用listener.onRegisterError() } } ``` 4. 在Activity中实现View接口,并创建Presenter对象 ```java public class LoginActivity extends AppCompatActivity implements LoginView { private EditText usernameEt; private EditText passwordEt; private Button loginBtn; private Button registerBtn; private ProgressBar progressBar; private LoginPresenter loginPresenter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_login); usernameEt = findViewById(R.id.username_et); passwordEt = findViewById(R.id.password_et); loginBtn = findViewById(R.id.login_btn); registerBtn = findViewById(R.id.register_btn); progressBar = findViewById(R.id.progress_bar); loginPresenter = new LoginPresenter(this); loginBtn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { String username = usernameEt.getText().toString(); String password = passwordEt.getText().toString(); loginPresenter.validateCredentials(username, password); } }); registerBtn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { String username = usernameEt.getText().toString(); String password = passwordEt.getText().toString(); loginPresenter.register(username, password); } }); } @Override public void onLoginResult(Boolean result, int code) { if (result) { Toast.makeText(this, "登录成功", Toast.LENGTH_SHORT).show(); } else { Toast.makeText(this, "登录失败,错误码:" + code, Toast.LENGTH_SHORT).show(); } } @Override public void onRegisterResult(Boolean result, int code) { if (result) { Toast.makeText(this, "注册成功", Toast.LENGTH_SHORT).show(); } else { Toast.makeText(this, "注册失败,错误码:" + code, Toast.LENGTH_SHORT).show(); } } @Override public void showProgress() { progressBar.setVisibility(View.VISIBLE); } @Override public void hideProgress() { progressBar.setVisibility(View.GONE); } @Override protected void onDestroy() { super.onDestroy(); loginPresenter.onDestroy(); } } ``` 以上就是使用MVP开发模式实现登录和注册功能的步骤,希望能对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

iamsujie

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值