- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
许多 View 都有 subview ,这些 subview 不一定需要关联自己的 Controller 。在苹果的 own tutorial在创建自定义 View 时,他们实际上并没有为每个 subview 创建一个子 UIViewController。
但是,我经常遇到这样的情况:我有一个 View 层次结构,其中 subview 的某些 subview 有一个发送网络请求的按钮。在那种情况下,我可以做一个目标:
myView.addTarget(self, action: "networkRequest:", forControlEvents: UIControlEvents.TouchDown)
然后在同一个 myView 类中我可以处理该网络请求,但这似乎打破了 MVC 模式。 View 不应该做逻辑,他们应该只是显示东西,对吗?
另一种选择 我们可以做的是让每个 View 都可以访问其逻辑所需的父 Controller 或祖父 Controller 。在这种情况下,我的目标可能类似于:
func networkRequest(view : MyView) {
self.controller.doNetworkRequest()
}
但这似乎也不是正确的解决方案。同样,我们似乎只是在破坏 MVC 并小心翼翼地退出。
因此,据我所知,我们只剩下两个选项之一:
首先,我们可以从父 Controller 本身添加目标和所有逻辑。但是这样做会给我们带来像这样的讨厌的链条:
self.grandParentView.parentView.childView.addTarget(self, action: "networkRequest:", forControlEvents: UIControlEvents.TouchDown)
那长长的访问列表让我不寒而栗,看起来很糟糕。但是,它似乎仍然遵循 MVC。从技术上讲,我们是在 Controller 中执行逻辑,对吧?
但可能还有另一种选择。我们可以只给每个 View 一个 Controller ,让每个 UIViewController 为每个新 subview 都有一个子 Controller 。
但是,有些 View 是静态的。它们实际上没有任何逻辑,因此它们不一定需要 Controller 。但是,如果我们要遵循这个约定,我们基本上每个 View 都需要一个,否则我们会在 Controller 有孙 Controller 但没有子 Controller 的情况下出现不一致。
所以我们只剩下为我们的 Controller 创建许多空棺材。这会产生大量永远不会被使用的死代码,这可能会导致一些软件腐烂。
比我聪明的人,这里的正确解决方案是什么?
最佳答案
可能有比我更聪明的 MVC 大师,但我会试一试:
如果您在 UIView 子类中处理网络请求,您肯定会破坏 MVC 模式。根据 Apple 的 MVC 引用资料:
A view object is an object in an application that users can see. A view object knows how to draw itself and can respond to user actions.
看起来, View 应该简单地处理用户可以看到的内容和与之交互的内容。不要不要走这条路。
让我们回到 Apple 的 View Controller MVC 引用:
A controller object acts as an intermediary between one or more of an application’s view objects and one or more of its model objects. Controller objects are thus a conduit through which view objects learn about changes in model objects and vice versa. Controller objects can also perform setup and coordinating tasks for an application and manage the life cycles of other objects.
注意文档是怎么说“一个或多个”的,因为 View Controller 处理多个 View 的逻辑是完全可以接受的。就个人而言,我会说如果您的 View 只有一个按钮需要网络请求委托(delegate),请继续并将父 View 的 View Controller 设置为委托(delegate)。
一旦 View 的数据处理变得“复杂”,您就应该让 View 拥有自己的 View Controller ,为简洁起见,我将其定义为“会混淆父 View View Controller 的明显目的的多个操作。”
也就是说,可以使用 #pragma mark
在 View Controller 中清楚地标记代码的确切原因,因此请在此处使用您的判断。
为每个 View 提供自己的 View Controller 绝对可行,但您真的认为有必要吗?每次您需要处理单个按钮点击时都创建一个全新的 View Controller ,如果应用程序是可扩展的,这肯定看起来有点矫枉过正。
使用选项 #2 并使用您的最佳判断。您不会因为破坏 MVC 模式而受到惩罚。最坏的情况是,如果 View 的逻辑变得复杂,您将把代码重构到新的 View Controller 中。
Model-View-Controller - iOS Developer Library
希望这对您有所帮助!
关于ios - 在 iOS 中,每个 UIView 都应该有一个 UIViewController 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33194006/
我需要将文本放在 中在一个 Div 中,在另一个 Div 中,在另一个 Div 中。所以这是它的样子: #document Change PIN
奇怪的事情发生了。 我有一个基本的 html 代码。 html,头部, body 。(因为我收到了一些反对票,这里是完整的代码) 这是我的CSS: html { backgroun
我正在尝试将 Assets 中的一组图像加载到 UICollectionview 中存在的 ImageView 中,但每当我运行应用程序时它都会显示错误。而且也没有显示图像。 我在ViewDidLoa
我需要根据带参数的 perl 脚本的输出更改一些环境变量。在 tcsh 中,我可以使用别名命令来评估 perl 脚本的输出。 tcsh: alias setsdk 'eval `/localhome/
我使用 Windows 身份验证创建了一个新的 Blazor(服务器端)应用程序,并使用 IIS Express 运行它。它将显示一条消息“Hello Domain\User!”来自右上方的以下 Ra
这是我的方法 void login(Event event);我想知道 Kotlin 中应该如何 最佳答案 在 Kotlin 中通配符运算符是 * 。它指示编译器它是未知的,但一旦知道,就不会有其他类
看下面的代码 for story in book if story.title.length < 140 - var story
我正在尝试用 C 语言学习字符串处理。我写了一个程序,它存储了一些音乐轨道,并帮助用户检查他/她想到的歌曲是否存在于存储的轨道中。这是通过要求用户输入一串字符来完成的。然后程序使用 strstr()
我正在学习 sscanf 并遇到如下格式字符串: sscanf("%[^:]:%[^*=]%*[*=]%n",a,b,&c); 我理解 %[^:] 部分意味着扫描直到遇到 ':' 并将其分配给 a。:
def char_check(x,y): if (str(x) in y or x.find(y) > -1) or (str(y) in x or y.find(x) > -1):
我有一种情况,我想将文本文件中的现有行包含到一个新 block 中。 line 1 line 2 line in block line 3 line 4 应该变成 line 1 line 2 line
我有一个新项目,我正在尝试设置 Django 调试工具栏。首先,我尝试了快速设置,它只涉及将 'debug_toolbar' 添加到我的已安装应用程序列表中。有了这个,当我转到我的根 URL 时,调试
在 Matlab 中,如果我有一个函数 f,例如签名是 f(a,b,c),我可以创建一个只有一个变量 b 的函数,它将使用固定的 a=a1 和 c=c1 调用 f: g = @(b) f(a1, b,
我不明白为什么 ForEach 中的元素之间有多余的垂直间距在 VStack 里面在 ScrollView 里面使用 GeometryReader 时渲染自定义水平分隔线。 Scrol
我想知道,是否有关于何时使用 session 和 cookie 的指南或最佳实践? 什么应该和什么不应该存储在其中?谢谢! 最佳答案 这些文档很好地了解了 session cookie 的安全问题以及
我在 scipy/numpy 中有一个 Nx3 矩阵,我想用它制作一个 3 维条形图,其中 X 轴和 Y 轴由矩阵的第一列和第二列的值、高度确定每个条形的 是矩阵中的第三列,条形的数量由 N 确定。
假设我用两种不同的方式初始化信号量 sem_init(&randomsem,0,1) sem_init(&randomsem,0,0) 现在, sem_wait(&randomsem) 在这两种情况下
我怀疑该值如何存储在“WORD”中,因为 PStr 包含实际输出。? 既然Pstr中存储的是小写到大写的字母,那么在printf中如何将其给出为“WORD”。有人可以吗?解释一下? #include
我有一个 3x3 数组: var my_array = [[0,1,2], [3,4,5], [6,7,8]]; 并想获得它的第一个 2
我意识到您可以使用如下方式轻松检查焦点: var hasFocus = true; $(window).blur(function(){ hasFocus = false; }); $(win
我是一名优秀的程序员,十分优秀!