百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

网站开发模式演进历程(网站的开发形式)

myzbx 2025-03-23 21:41 39 浏览

我们现在基本每天都会浏览网站,那么网站的开发其实经历了几个较大的演进历程,接下来从特定视角介绍一下主要开发模式的演化过程。

  • 静态网站
  • 动态网站
  • 服务端渲染与客户端渲染结合
  • 前后端分离

静态网站

早期的网站基本上都是静态的,所谓静态并不是页面是静止的,没有动画效果,而是把网站所有的网页开发好之后直接上线部署到服务器上,那么这些页面就固定放到服务器之上,如果上线时是100个页面,那么如果不更新,该网站就是写死的100个页面了,这就是所谓的“静态网站”。静态网站的内容主要包括HTML、CSS、javascript代码,图片、字体文件、音频、视频等资源。其交互流程如下图所示:

静态网页访问流程

  • 客户端向服务器发送请求
  • Nginx根据请求路径获取网页内容
  • 将页面内容传输给客户端
  • 客户端展示网页效果

静态网站有明显的局限性:

  1. 如果需要更新页面的内容,比如说,每个页面添加一条广告信息,会很麻烦,需要一个一个页面进行修改,工作量比较大,尤其是大规模的网站,这种方式基本不可行。
  2. 无法实现交互效果,比如登录,发表评论、点赞等功能。

动态网站

鉴于静态网站的问题,后来就诞生了动态网站技术、比如PHP、JSP、ASP等。所谓的动态网站也不是页面有动画,而是指页面是通过技术手段动态生成的。比如银行的账单页面,张三和李四会看到不同的数据,但是在服务器中仅仅一个动态页面就够了,当张三和李四分别访问该动态页面时,会分别动态生成两个不同的HTML页面,动态性体现在HTML的动态生成上。

以PHP动态网站技术为例,具体流程如下

  • 客户端访问服务器的php页面
  • Nginx根据请求路径找到php文件
  • Nginx把php文件交给php运行环境进行编译,转换成静态HTML页面,然后交给Nginx
  • Nginx把动态生成的HTML页面返回给客户端
  • 浏览器展示页面效果

服务端渲染与客户端渲染结合

无论是静态网站还是动态网站,当浏览器发送请求之后,如果服务器返回内容的时间比较慢(可能是网络问题),那么浏览器只能等待,处于阻塞状态,呈现出的效果就是长时间白屏,在当今快节奏的生活模式下,坐高铁、吃快餐......这些习惯已根深蒂固,当一个页面3秒左右不出来,我们甚至都不愿意去等。

所以为了改善用户体验,2005诞生了一种技术Ajax,他可以使浏览器在不阻塞的情况下,向服务器发送请求,用户是无感知的,当服务器返回数据后,页面再根据数据进行局部更新。有了Ajax这种技术,再配合jQuery,基本上就成了前端的主要开发模式,这也是此后jQuery近10年的辉煌时期(当然现在有了更好的选择—Vue/React/Augular)。

接下来需要着重解释一个概念:渲染。所谓的渲染就是把数据填充到HTML标签的过程。

还是以查看账单的场景为例,账单数据一般都是存储在数据库中,那么php代码会从数据库中查询出数据然后拼接到HTML标签代码中,这个过程发生在服务器,所以称之为服务端渲染。流程如下图所示:

客户端请求得到服务端渲染的HTML页面之后先进行展示,如果用户触发操作要更新页面,还可以通过Ajax请求获取后端返回的数据(当前基本上是JSON格式的数据),从而实现页面的局部更新。比较典型的场景有触底加载更多列表内容的效果,当页面滚动到底部的时候,页面上面的内容不会消失,而是在底部显示Ajax请求的一页新的数据,这种效果体验非常好。那么服务器如果仅仅返回JSON数据,页面端会通过javascript代码把数据填充到HTML标签中进行显示,这种数据填充标签的过程发生在浏览器,即所谓的客户端渲染

jQuery时代基本上是服务端渲染和客户端渲染结合使用,一般主页面采用服务端渲染,主页展示之后,后续页面局部更新操作一般基于Ajax,采用客户端渲染方式,从而提升交互体验。

前后端分离

随着互联网的持续繁荣,客户端基于Ajax渲染的业务场景越来越复杂,那么把JSON数据拼接到HTML标签中的代码实现越来越繁琐,代码变得难以维护。虽然出现了像art-template之类的前端模版引擎,从某种程度上有所改善,但是像事件处理还是需要自己去操作,并未从根本上解决问题。

好在2009年一种技术的诞生奠定现今前端更加繁荣的开发模式:Node.js

Node.js可以让javascript运行在非浏览器环境,并且提供了对接底层操作系统API的能力。经过十多年的发展,这个生态已经非常繁荣。新兴的前端框架基本都是构建在Node.js生态之上,包括目前比较流行的AngularJS、Vue、React。

新兴前端框架,比如以React为例,基本上颠覆了前端代码的开发模式,将程序员从繁琐的DOM操作中解脱出来,而仅仅需要关注数据处理和业务操作,从而大大简化了前端的代码实现。此外更重要的一点就是,前后端从项目结构和开发流程上彻底分离,让前端和后端可以更加专注(其实都可以少掉点儿头发),而之前很多后端基本都是做全栈的工作。

在这种前后端分离的开发模式下,具体流程如下

在这种前后端分离的模式下,前后与后端的对接仅仅需要约定一种接口(接口细节包括请求地址,请求方式、请求参数,后端返回的结果),那么这种接口是与技术无关的,所以前后的技术选型可以自由设计,前端可以选择React、Vue等都可以,后端可以选择java、PHP、python等亦无所谓。

对于前端来说,一个很大的变化,就是前端项目可以单独实现工程化,可以独立设计、开发、测试、部署上线以及运维等。所以这套流程靠后端已经不太容易兼职搞定了,所以前端工程师这个岗位才有了一席之地,并且可以与后端工程师分庭抗礼。

相关推荐

任天堂Switch OLED:一块沉浸屏,点燃全家欢乐的游戏时光

在一个寻常的周末午后,客厅里弥漫着轻松惬意的氛围。电视屏幕暂时休眠,全家人的目光却聚焦在那台轻巧的掌上设备——任天堂SwitchOLED。父母与孩子挤在沙发上,指尖在Joy-Con手柄上跃动,时而因...

Switch是什么地区的版本?怎么分辨Switch普通版和续航版、OLED版

Switch有国行、港版、日版、美版、欧版、韩版,版本之间又有普通版和续航版的OLED区别。只要看掌机的序列号第二三位,第二位代表的机型,A是普通版,K是续航版,T是OLED版。第三位代表的是区域,比...

这款Switch手柄真别致!开箱体验八位堂Lite蓝牙手柄

【引言】Hi大家好,我是歌布林,今天给大家带来一款八位堂Lite蓝牙手柄的开箱报告!相信已经有不少Switch玩家已经入手了这款产品,讲真,这款手柄的颜值真的吸引到我了~双十一旗舰各大快递公...

switch 的性能提升了 3 倍,我只用了这一招

上一篇《if快还是switch快?解密switch背后的秘密》我们测试了if和switch的性能,得出了要尽量使用switch的结论,因为他的效率比if高很多,具体原因点击上文查看。既...

在对《Nintendo Switch 运动》充满期待的同时,我也有些许不安

任天堂「运动」系列的最新作《NintendoSwitch运动》即将于4月29日正式发售。在等待本作发售的日子里,笔者每一天都在掰着指头计算发售日还有几天才到来。在《NintendoSwi...

switch上最值得玩的五款JRPG(switch最值得玩的大作)

不知道为什么即使现在节奏变得这么快,人也变得浮躁,我依旧喜欢玩JPRG,喜欢沉浸入游戏的角色之中体验一场独特的冒险。JRPG的灵魂是什么?那绝对不是回合制战斗或者古旧的系统,而是令人深刻的剧情及在这漫...

那个 Vue 的路由,路由是干什么用的?

在Vue里,路由就像“页面导航的指挥官”,专门负责管理页面(组件)的切换和显示逻辑。简单来说,它能让单页应用(SPA)像多页应用一样实现“不同URL对应不同页面”的效果,但整个过程不会刷新网页。一、路...

S235JRH材50x50x3-5mm欧标方管疲劳强度分析

在工程与建筑领域,方管作为一种重要的结构材料,广泛应用于各种框架和支撑结构中。S235JRH材质的50x50x3-5mm欧标方管在疲劳强度方面的表现尤其受到关注。本文将以“解答常见误区”的形式,分析该...

纤维丛上的联络与曲率关系之二:七个联络

参阅一文看懂纤维丛(看图说话)纤维丛上的联络与曲率关系之一1.仿射联络(AffineConnection)定义:在光滑流形M的切丛TM上,一个仿射联络是一个双线性映射:仿射联络定义了向量...

安全完整性等级(SIL)分析报告编制与认证实践方法

以下是一篇关于安全完整性等级(SIL)分析报告的文章,涵盖SIL定级方法、验证流程、计算模型及工程实践。安全完整性等级(SIL)是量化安全仪表系统(SIS)性能的核心指标,由IEC61508/615...

欧标方管75x75x3mm8mm S355J0H力学性能测试

欧标方管75x75x3mmS355J0H是一种常见的钢管材料,广泛应用于建筑、机械制造和结构工程等领域。下面将对其力学性能进行详细测试和分析。1.材料概述S355J0H是欧洲标准EN10210中规定的...

p光与s光在SHG中的相位匹配中有哪些不同?

【第六期】p光与s光在SHG中的相位匹配中有哪些不同?在二次谐波生成(SHG)中,p偏振光和s偏振光的相位匹配条件存在显著差异。这些差异主要源于它们与纳米结构相互作用的方式以及它们在激发表面等离子体共...

S355JRH欧标方管机械性能及工程应用解析

S355JRH欧标方管是一种高强度钢管,以其优良的机械性能和良好的加工性在工程领域得到广泛应用。本文将从机械性能、场景应用等方面对S355JRH欧标方管进行解析,以帮助读者更好地理解其特性及应用。1....

《三国志·战棋版》PK7黄天蔽汉,四队共存作业来啦!

哈喽大家好啊,今天要给大家分享的是三棋PK7黄天蔽汉平时四队共存队,这只是其中一种选择供大家参考,后面可能还会分享其他的四队共存方案。队伍共存绝不唯一,大家有什么好的共存方案或者想看哪些队伍的共存也欢...

迈阿密三大巨星首秀被0-0逼平,豪阵为何难赢开罗国民

谁能想到,汇聚梅西、苏亚雷斯、布斯克茨这“银河战舰”级别三巨头,迈阿密国际世俱杯首秀居然0-0被埃及劲旅开罗国民逼平?全场90分钟,球迷的心情从“期待冠军”一路跌到“差点开门黑”。补时第96分钟,梅西...