是否可以在Android版Java中实现模型-视图-控制器模式?
还是已经通过活动实施了?还是有更好的方法来为Android实现MVC模式?
是否可以在Android版Java中实现模型-视图-控制器模式?
还是已经通过活动实施了?还是有更好的方法来为Android实现MVC模式?
Answers:
在Android中,您没有MVC,但是您具有以下条件:
没有通用的MVC模式。MVC是一个概念,而不是坚实的编程框架。您可以在任何平台上实现自己的MVC。只要您坚持以下基本思想,就可以实现MVC:
还要这样考虑:在对模型进行编程时,模型不必担心渲染(或平台特定的代码)。该模型将对视图说,我不在乎您的渲染是Android还是iOS还是Windows Phone,这就是我需要您渲染的内容。该视图将仅处理特定于平台的呈现代码。
当您使用Mono共享模型以开发跨平台应用程序时,这特别有用。
经过一番搜索,最合理的答案如下:
MVC已在Android中实现为:
Button
从android.view.View
。(顺便说一下,这意味着活动中没有应用程序域逻辑。)
对于小型开发人员而言,最合理的做法是遵循这种模式,而不是尝试做Google决定不做的事情。
PS注意,Activity有时会重新启动,因此它没有放置模型数据的位置(导致重新启动的最简单方法是android:configChanges="keyboardHidden|orientation"
从XML中忽略并打开设备)。
编辑
我们可能在谈论MVC,但是可以说FMVC是Framework--Model--View--Controller。该框架(Android OS)强加了其组件生命周期和相关事件的概念,并且在实践中,控制器(Activity
/ Service
/ BroadcastReceiver
)首先负责处理这些框架施加的事件(例如onCreate())。用户输入是否应该单独处理?即使需要,也无法将其分开,用户输入事件也来自Android。
无论如何,将更少的非Android专用代码放入Activity
/ Service
/ BroadcastReceiver
会更好。
Button
了解控制器的孩子?Views只知道显示事物似乎更合乎逻辑。考虑到Model仅了解数据的性质,这就是为什么需要Controller的原因:必须同时了解Model和View。
Service
也属于控制器的保护范围
您没有一个MVC模式可以服从。MVC只是或多或少地声明您不应该混合数据和视图,以使例如视图负责保存数据或正在处理数据的类直接影响视图。
但是,尽管如此,Android处理类和资源的方式有时甚至被迫遵循MVC模式。在我看来,更复杂的是有时负责视图的活动,但同时又充当控制者。
如果您在XML文件中定义视图和布局,请从res文件夹中加载资源,并且如果避免或多或少地在代码中混杂这些内容,那么您还是遵循MVC模式。
您可以在Android中实现MVC,但是“本地不支持”该MVC会花费一些精力。
也就是说,我个人倾向于将MVP作为Android开发的一种更简洁的架构模式。通过说MVP,我的意思是:
我还在这里发布了更详细的答案。
在尝试了在Android中实现MVC / MVP的各种方法之后,我想出了一个合理的架构模式,在这篇文章中对此进行了描述:Android中的MVP和MVC架构模式。
我同意JDPeckham的观点,并且我相信仅XML不足以实现应用程序的UI部分。
但是,如果将“活动”视为视图的一部分,则实现MVC非常简单。您可以覆盖Application(由Activity中的getApplication()返回),在这里您可以创建一个在应用程序生命周期内都可以生存的控制器。
(或者,您可以按照应用程序文档的建议使用单例模式)
Android上的 MVC 体系结构最好遵循任何MVP,而不是android中的MVC。但是仍然根据问题的答案这可以解决
说明和准则
Controller -
Activity can play the role.
Use an application class to write the
global methods and define, and avoid
static variables in the controller label
Model -
Entity like - user, Product, and Customer class.
View -
XML layout files.
ViewModel -
Class with like CartItem and owner
models with multiple class properties
Service -
DataService- All the tables which have logic
to get the data to bind the models - UserTable,
CustomerTable
NetworkService - Service logic binds the
logic with network call - Login Service
Helpers -
StringHelper, ValidationHelper static
methods for helping format and validation code.
SharedView - fragmets or shared views from the code
can be separated here
AppConstant -
Use the Values folder XML files
for constant app level
注意1:
现在,这是您可以做的魔术。对代码进行分类后,编写一个基础接口类,例如IEntity和IService。声明常用方法。现在,创建抽象类BaseService并声明您自己的方法集并进行代码分离。
注意2:如果您的活动正在呈现多个模型,则与其在活动中编写代码/逻辑相比,不如将视图分成多个片段。那就更好了。因此,将来如果需要在视图中显示更多模型,请再添加一个片段。
注意3:代码分离非常重要。体系结构中的每个组件都应独立且没有逻辑。如果您碰巧有某种依赖逻辑,则在两者之间编写一个映射逻辑类。这将对您将来有所帮助。
使用布局,资源,活动和意图创建Android UI是MVC模式的一种实现。请参阅以下链接了解更多信息-http: //www.cs.otago.ac.nz/cosc346/labs/COSC346-lab2.2up.pdf
描述:
MVC模式本质上是这样的:
MVC的重要功能: 我们可以修改Model或View或Controller仍然不影响其他
我认为最有用的简化说明在这里:http : //www.cs.otago.ac.nz/cosc346/labs/COSC346-lab2.2up.pdf
从我在这里看到和阅读的所有其他内容来看,实现所有这些东西会使它变得更加困难,并且与android的其他部分不太匹配。
通过活动实现其他侦听器已经是Android的标准方法。最无害的方法是像幻灯片中描述的那样添加Java Observer,并将onClick和其他类型的操作分组为仍在Activity中的功能。
Android的方式是Activity可以同时执行。对抗它并没有真正使扩展或将来编写代码变得更加容易。
我同意第二个职位。它已经实现了,而不是人们习惯的方式。无论是否在同一文件中,都已经存在分隔。无需创建额外的分隔符以使其适合其他语言和操作系统。
令人惊讶的是,这里没有任何帖子回答了这个问题。它们要么太笼统,含糊,不正确,要么不解决android中的实现。
在MVC中,视图层仅知道如何显示用户界面(UI)。如果为此需要任何数据,它将从“ 模型”层获取数据。但是View不会直接要求模型找到数据,而是通过Controller来完成。因此,Controller 调用Model为View提供所需的数据。数据准备就绪后,控制器将通知View已准备好从模型中获取数据。现在,视图可以从模型获取数据。
该流程可以总结如下:
值得注意的是,View可以 通过Controller(也称为 被动MVC)或通过向模型注册可观察对象(即Active MVC)来观察模型中的数据,从而了解模型中数据的可用性 。
在实现部分,首先想到的一件事情是View应该使用哪个android组件?Activity
还是Fragment
?
答案是没有关系,两者都可以使用。该视图应该能够呈现设备和响应上的用户界面(UI),以用户与用户界面的交互。双方Activity
并Fragment
为此提供必要的方法。
在使用的示例应用程序这篇文章中我已经使用Activity
了视图层,但Fragment
也可以使用。
完整的示例应用程序可以在“MVC”分支找到我的GitHub库在这里。
我还通过此处的示例介绍了Android中MVC架构的优缺点。
对于那些有兴趣,我已经开始了一系列的Android应用程序架构的文章在这里通过一个完整的工作程序中,我比较了不同的架构,即MVC,MVP,MVVM,为Android应用开发。
厌倦了Android上的MVx灾难,我最近制作了一个微型库,该库提供了单向数据流,类似于MVC的概念:https : //github.com/zserge/anvil
基本上,您有一个组件(活动,片段和视图组)。在内部定义视图层的结构和样式。您还定义了数据应如何绑定到视图。最后,您可以在同一位置绑定侦听器。
然后,一旦您的数据被更改-全局“ render()”方法将被调用,并且您的视图将使用最新数据进行智能更新。
这是一个组件的示例,其中的所有组件内部都具有代码紧凑性(当然,可以轻松分离Model和Controller)。这里的“ count”是一个模型,view()方法是一个视图,“ v-> count ++”是一个监听按钮单击并更新模型的控制器。
public MyView extends RenderableView {
public MyView(Context c) {
super(c);
}
private int count = 0;
public void view() {
frameLayout(() -> { // Define your view hierarchy
size(FILL, WRAP);
button(() -> {
textColor(Color.RED); // Define view style
text("Clicked " + count); // Bind data
onClick(v -> count++); // Bind listeners
});
});
}
使用分离的模型和控制器,它看起来像:
button(() -> {
textColor(Color.RED);
text("Clicked " + mModel.getClickCount());
onClick(mController::onButtonClicked);
});
在每个按钮上,单击此数字将增加,然后将调用“ render()”,并且按钮文本将被更新。
如果您使用Kotlin,则语法会变得更加愉悦:http: //zserge.com/blog/anvil-kotlin.html。另外,没有lambda的Java还有其他语法。
该库本身非常轻巧,没有依赖项,不使用反射等。
(免责声明:我是这个图书馆的作者)
没有实现的MVC体系结构,但是存在一组实现MVP(模型-视图-演示者)体系结构的库/示例。
请检查以下链接:
Google添加了一个Android架构MVP的示例:
我已经看到很多人说MVC已经在Android中实现,但这不是事实。Android默认不遵循MVC。
因为我不是Google会强加诸如iPhone之类的MVC实现的限制,但是它取决于开发人员在项目中想要的模式或技术,因此在小型或简单应用程序中,不需要使用MVC,但作为应用程序后来变得越来越复杂,需要对其代码进行修改,因此需要Android中的MVC模式。
它提供了修改代码的简便方法,还有助于减少问题。如果您想在Android上实现MVC,请按照以下给定的链接进行操作,并在您的项目中享受MVC的实现。
http://www.therealjoshua.com/2011/11/android-architecture-part-1-intro/
但是如今,我认为MVP与Android Architectural Pattern一起是开发人员开发干净和强大的android应用程序的最佳选择之一。
当我们将MVC,MVVM或Presentation Model应用于Android应用程序时,我们真正想要的是拥有一个清晰的结构化项目,更重要的是,它更易于进行单元测试。
目前,如果没有第三方框架,您通常会有很多代码(例如addXXListener(),findViewById()等)不会增加任何业务价值。
而且,您必须运行Android单元测试,而不是普通的JUnit测试,这需要花一些时间才能运行,并使单元测试有些不切实际。基于这些原因,几年前,我们启动了一个开源项目RoboBinding-一个用于Android平台的数据绑定Presentation Model框架。
RoboBinding帮助您编写易于阅读,测试和维护的UI代码。RoboBinding消除了对诸如addXXListener之类的不必要代码的需求,并将UI逻辑转移到Presentation Model,这是一个POJO,可以通过常规JUnit测试进行测试。RoboBinding本身随附300多个JUnit测试以确保其质量。