闲话Web编程模型:WebForm、MVP还是MVC?

2023-11-28 03:08

本文主要是介绍闲话Web编程模型:WebForm、MVP还是MVC?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    此文写给所有还在迷茫中的初学者并欢迎高手进来讨论。
    首先什么是Web编程模型?在这里我们定义Web编程模型为如何编写代码生成html返回给最终用户的方法。它包括两部分,一个是如何编写Web应用程序的规范,另一个则是实现这一规范的Web编程框架,而ASP.NET就是用来实现WebForm模型的框架,当然ASP.NET的功能比较强大,留下了足够的空间,足够我们在此基础之上实现另外的模型,比如MonoRails。换个比方,和ASP.NET比较类似的,Jsp,Servlet也是实现Web 编程模型的基础结构,Sun所定义的Jsp2.0规范定义了一个如何编写Web应用程序的规范,当然你可能不喜欢这么做,那么你还可以使用Struts或者SpringMVC,不过换汤不换药,之不过是换了一种做法而已。
    WebForm其实是一个很好的Idear。在我才接触WebForm编程的时候,当时的感触是原来Web下还能这么写程序。在WebForm模型下,我们将整个浏览器当成一个窗体来进行编程,把页面上的元素都作为控件来操作,拖放式,基于事件,不再是面条式的流程控制,一切都是那么的美好。但是很快的,随着使用WebForm开发的项目数量越来越多,就越来越感觉到其中的弊端,其实罪过不在WebForm,而是在于微软,把这么好的概念给糟蹋了。
    WebForm的原罪:
    其一:控件管得太宽,滥用Html样式:
        所有的控件都通过Html样式管理自己的外观,结果就算增加了Css属性,但是Vs在编辑控件的时候随便点一点就自作主张的给你加上了 Html样式,很多时候还会很恶心的给你加上<font>标记,结果美工做得好好的Html代码在Vs里很快就变得面目全非,很多对Html 熟悉的程序员就直接在Html视图编辑代码,结果WebForm 的所见即所得和拖放的特性就又丧失了。这一点在很注重外观输出的网站项目中很突出,结果是本来能够提高效率的特性反而降低了效率。就算是在企业内部系统,领导要看的也是外观,所以这一点是我极其厌恶的,自从2003以来就这样了,而多年来微软依然故我,完全没有改变。
    其二:事件驱动,却不彻底,结果造成初学者理解困难,而代码也很丑陋
        主要指的就是那个很不清晰的Page_Load事件,玩过WinForm下编程的都知道,窗体确实有一个Load事件,但是微软在处理 Page_Load的时候有一个很重要缺点,既然费了老大的力,用ViewState,不惜牺牲性能也要在WebForm下保证页面看起来是保持了状态的,也就是说在离开这个页面前,这个页面是要保持状态的,那么在离开这个页面之前,这个页面就只能Load一次,但是在微软的WebForm下却每一次都要Load页面,所以很多从Winform转过来的程序员在这里就迷惑了。在之前的很多同学的Post里都对这一点表示过不满。但是看起来6年过去,微软仍然没有打算改正这一点,却去费力的推MVP还弄了个MVC什么的。其实把这一点
改正了,我都愿意给WebForm加分。
    其三:页面的表现和事件的逻辑混淆在一个类中。
        其实也就是aspx页面和aspx.cs文件的关系问题,这一点微软在推MVP的时候其实也就是在这一点上做出了改进。不过.cs文件到底是处理表示逻辑还是处理什么其实大多数人都是迷糊。而且据某人的Post里说新加坡的某大牛宣称.CS就是控制器,Ok,就这点来说都是很混乱了,既然混乱,说明这里也是个问题。
    我们该怎么办?其实很简单两个字:凉拌。既然微软已经这么做了,而我们靠ASP.NET吃饭的,如果要使用WebForm模式来编程,那么我们也只有认命,然后改变可以改变的,克服不可改变的。框架的限制并不是我们不能完成项目的接口,而其他很多因素都比这一点更能影响项目的完成。所以与其费力在这一点上批评微软,不如在项目管理上多花点功夫来得要紧。
    MVP由于是在WebForm的基础上改进出来的,我也使用很少,就留给有深入了解的大牛来解释了,我在这里只有一点粗略的了解,就是MVP大约用来改进aspx和.cs耦合的问题,也就是WebForm的一个改进版,不过没有编辑器的支持,而且一二两点问题也没有克服。一个子:唉!
    最后是MVC,其实MVC比起WebForm来更加的古老,作为一个种设计模式来说,其实把MVC应用于Web编程来说确实是老师傅遇到了新问题。首先是Web环境是属于一种瘦客户端的环境,所以在表示层:Html的能力其实很弱,只有get,post等有限的几种方法,而且只能够使用拉的方式,也就是每一次数据的更新都是通过浏览器主动发出请求而开始的,而经典的MVC模型所要求的当模型发生变化的时候通知视图刷新界面其实就成了 mission imposiable,那么现在在Web上的MVC框架其实都是经典MVC的变种,或者有人称之为InputController,不过将表示,控制,模型分离开的思想其实是没有错的。也可以说在Web下的MVC其实也就是另外一种思考的模式而已,既然思考的方式不同,那么要在WebForm下混合MVC 也就成了不可能的任务。很多人这么做的目的,也不过是既不想放弃方便的WebForm,有想要在设计上有清晰的代码模型。虽然个人并不看好,但是但愿能有人成功吧。
    总的来说WebForm和MVC不过是一种选择而已,既然选择了其中一种,也就是说路只有一条,改变可以改变的,接受不能改变的。或许有人想也许路不止这两条,而ASP.NET也留给了我们足够的自由度去实现我们所认定的不同的Web编程方式。但是其实结果都是一样,如果真的是百花齐放,结果可能和python下的Web框架一样变得无从选择。而至于MonoRails,嗯,个人来说不是很喜欢,由于在公司我并不负责具体项目的编程任务所以我也不大喜欢一些一揽子解决方案,什么都要负责,但是却存在了过大的学习负担,MonoRails对我来说太重了,很多时候我们只是需要一把起子的时候却递给你了一把瑞士军刀。
    最后,正如怪怪所说,WebForm和MVC的争论其实大可不必,不是一路的何必强求,与其争论如何选择,不如多花点时间在项目管理上,说不定收到的效果然而更好。多优化优化项目的管理,早点下班休息,多点时间回家陪陪父母,多点时间学习新东西,这才是正道啊。
    By the way,在java里也不是MVC一统天下。感兴趣的可以去看看Apache下的 Tapestry项目,感觉很类似WebForm了的事件驱动了,不过实现上区别还是很大。而上次在谈金蝶的Opramask的时候也是感觉有些类似WebForm的感觉。

 

 

转自:http://info.codepub.com/2008/10/info-22939.html

 

这篇关于闲话Web编程模型:WebForm、MVP还是MVC?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/428951

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

Java Web指的是什么

Java Web指的是使用Java技术进行Web开发的一种方式。Java在Web开发领域有着广泛的应用,主要通过Java EE(Enterprise Edition)平台来实现。  主要特点和技术包括: 1. Servlets和JSP:     Servlets 是Java编写的服务器端程序,用于处理客户端请求和生成动态网页内容。     JSP(JavaServer Pages)

图神经网络模型介绍(1)

我们将图神经网络分为基于谱域的模型和基于空域的模型,并按照发展顺序详解每个类别中的重要模型。 1.1基于谱域的图神经网络         谱域上的图卷积在图学习迈向深度学习的发展历程中起到了关键的作用。本节主要介绍三个具有代表性的谱域图神经网络:谱图卷积网络、切比雪夫网络和图卷积网络。 (1)谱图卷积网络 卷积定理:函数卷积的傅里叶变换是函数傅里叶变换的乘积,即F{f*g}

秋招最新大模型算法面试,熬夜都要肝完它

💥大家在面试大模型LLM这个板块的时候,不知道面试完会不会复盘、总结,做笔记的习惯,这份大模型算法岗面试八股笔记也帮助不少人拿到过offer ✨对于面试大模型算法工程师会有一定的帮助,都附有完整答案,熬夜也要看完,祝大家一臂之力 这份《大模型算法工程师面试题》已经上传CSDN,还有完整版的大模型 AI 学习资料,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言