抽象

最近在公司和一些同事交流的时候发现了一点,就是大部分人其实是很难接受“代码和数据没有本质区别”这一点的。举例来说,他们认为一段HTML代码(或者当然也可以是JavaScript之类的),

    <div id="1">
        wahaha
    </div>

和一段XML数据

    <test>
        subara
    </test>

相比,意义是截然不同的。同样,作为分别执行这两段“字符串”的一个是浏览器,相比另一个可能是桌面客户端之类的C#程序,也是有本质区别的(区别当然就是一个是执行代码决定怎么展示,另一个只是用程序定义好的控件显示传过来的数据)。当时一起讨论问题的其实不乏一些资深的“工程师”和“开发者”,但是听到一些人异口同声的反驳我(并且没有人主动支持我的观点)时,我不经在脑海里想到,“他们不懂编程”,令人难过的是这太常见了。

会引出这个话题,主要是开始在讨论MVC,然后就自然而然的说起了SpringMVC,然后讨论到作为View通常支持的一些模板语言(JSP、Velocity等),很自然的我就提到了“不使用View也是一种View”,很显然我所指的是常见的前后端分离的方式由后端应用提供数据(例如JSON)来支持前端渲染的做法。

不幸的是,我的观点(很奇怪的)并没有得到大家的理解,讨论的过程就略去了,主要的分歧就是上面列出的观点,大家普遍接受的观点就是“View是指最终呈现在用户面前的(这里就是Web页面了)东西”,如果只是返回数据的应用,那就称不上是MVC Web应用,而是类似于API应用之类的Whatever什么东西。

当然,虽然讨论的当时我没有想到要去列举,但是其实我们是可以从Spring支持的ViewResolver类型来倒推这个MVC框架设计者关于View的理解的。具体这里的ViewResolver除了模板语言视图还支持哪些类型的返回值就留给大家自己查询和参考吧:)

然后关于代码和数据的相关的思考,我记得最早是在<SICP>上看到的,当然,在这里我也无意在做一遍并不准确的解释,有兴趣的人自然会去翻书。。。

    > '(car (a b))
    '(car (a b))
    > (car '(car (a b)))
    'car
    > (cdr '(car (a b)))
    '((a b))

大概就是这种感觉吧。当然上面也不是说把View单纯当做展现给用户看得东西就是错的理解,只是在更加抽象、简洁的解释面前,会显得相对来说不那么准确了吧。就酱。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,059评论 25 709
  • 该论文来自Berkeley实验室,英文标题为:Resilient Distributed Datasets: A ...
    九七学姐阅读 5,802评论 0 3
  • 原文地址:iOS应用架构谈 view层的组织和调用方案 当我们开始设计View层的架构时,往往是这个App还没有开...
    Jabir_Zhang阅读 4,383评论 0 1
  • 在麦当劳的角落里,对着一杯咖啡。翻遍了朋友圈、qq、无聊图、知乎新鲜事,一杯咖啡还有半杯,时间是下午4点,国庆长假...
    剑数阅读 1,072评论 0 0
  • 生病,对人来说,是件很平常的事情。现在却伴我如影随形。我不知道自己怎么了,喉咙痛到,难以说话。沙哑的话语...
    鹿鹿无畏阅读 3,746评论 2 47