现在Web开发中框架应用很普遍,但也有人追求不用框架来制作Web应用,这确实挺吸引人的,因为框架有很多好处,不按常理出牌肯定有它的独特理由。
理解框架与应用程序逻辑
应用软件必须设定自身的运行规则。若为了实现某种逻辑而自行搭建框架,这并不意味着框架本身有问题。然而,有时不使用框架反而能让我们更集中精力关注软件的独特需求。例如,有些业务需求非常个性化,若在框架中开发,可能会受到框架预设的种种限制。当我们深入分析软件的具体功能时,会发现自建框架可能只适合特定的业务,而与通用框架的广泛适用性有所不同。
用框架来制作软件似乎挺简单,但换个角度想,框架事先设定了许多标准。在开发软件时,我们可能只用到其中一小部分功能。如果专门针对自己的软件需求来构建,就能避免很多不必要的设定,实现真正的集中精力。比如,一个小公司内部使用的办公系统,只需记录员工出勤和任务分配,无需框架里复杂的权限管理等功能。
不使用框架的难度评估
很多人认为不用框架来开发应用很复杂。但其实并没有那么困难。要构建一个框架,必须全面考虑技术的融合和功能的整合。而如果不使用框架,就不必做构建框架时的工作。比如,在开发一个简单的在线日记系统时,就不需要像开发Web框架那样,去整合多种数据库和复杂的前端交互框架。
大多数应用都是基于框架来开发的,若没有这些常用的框架工具,确实很难找到实现目标的方法。然而,随着技术标准的持续进步,主流浏览器已经能够支持众多新功能,这为不依赖框架的开发带来了一定的便利。例如,当前的HTML5和CSS3等标准,使得我们无需复杂框架也能制作出既美观又实用的网页。
超集语言在其中的作用
超集语言是一种独特的编程语言。它就像一座桥梁。它能够减少某些限制。比如,它能够减少其他编程语言带来的“要么全有要么全无”的约束。它还提供了一些类型检查的支持,比如JSDoc注释(如@type)和class关键字。在实际的开发过程中,如果我们需要开发一个简单的数据展示应用,超集语言可以在不依赖大型框架的情况下轻松实现界面逻辑的关联。
然而,不少自称非框架的文档或文章却可能让开发者感到困惑。即便它们没有明确界定为框架,一旦含有约束,本质上就等同于框架。以某些开发工具为例,它们声称不构建完整应用,因此不算框架,但在具体操作上却限制了开发者自由组合的能力,这就使得它们与框架的作用相近。
开发者的担忧与思考
面试开发者时,谈及构建常规应用时可能遇到的困扰,常会引发一些典型的反应。很多开发者首先会考虑到模型变动检测和视图更新这类框架中常见的问题。然而,这种过分依赖框架的思维模式存在不足。在处理一些基础需求时,实际上并不需要框架。以一个简单的文字排版网站为例,其主要功能是展示内容,无需框架来处理复杂的数据交互。
将逻辑融入用户界面并非明智之举,用户界面应当专注于信息的呈现。通常情况下,逻辑处理应交由纯JavaScript完成,之后再将模板嵌入。比如,若要打造一个仅展示信息的网站,其逻辑部分便可仅用JavaScript编写,并嵌入HTML模板,这样的开发过程既简明又高效。
组件的HTML渲染结果要求
无论选用哪种设计方法,组件和它们的视图都必须生成HTML显示效果。尽管某些组件与纯JS实现看起来差别不大,但它们缺乏相互操作的能力,最终还是得依赖纯JS或Web组件。比如,制作导航栏组件时,最终需要在HTML中找到相应的显示元素,以便在网页上展示出来。
若组件设计不当,缺乏兼容性,便会引发诸多问题。尤其在大型Web应用整合过程中,若无法与其它模块顺畅交流并生成HTML显示效果,整个项目便会存在众多缺陷。
不使用框架的开发目的
开发Web应用不依赖框架,主要是独立进行编程。这并非意味着要废弃框架,而是指要打造满足特定需求的应用。举例来说,为某一商业产品打造专门的在线推广页面,这样的页面无需通用引擎,只需根据推广需求设计个性化的页面交互等功能。
{WelcomeModule} = await import("./welcome/ModuleImpl")
module = new WelcomeModule()
各位读者,在你们从事Web开发工作时,是否考虑过不用框架进行开发的可能?若有此想法,是哪些具体场景激发了你们的思考?期待大家积极交流,同时欢迎点赞和转发这篇文章。
interface WelcomeMessages {
title: string
greetings(user: string, unreadCount: number): string
}
class WelcomeMessage_en implements WelcomeMessage {
title = "Welcome !",
greetings = (user, unreadCount) => `Welcome ${user}, you have ${unreadCount} unread messages.`
}
class WelcomeMessage_fr implements WelcomeMessage {
title = "Bienvenue !",
greetings = (user, unreadCount) => `Bienvenue ${user}, vous avez ${unreadCount} nouveaux messages.`
}