当前位置: 首页 > news >正文

Blazor的SSR服务端渲染是不是交互式的

从.NET8开始,Blazor引入了SSR服务端渲染,归功于MVC和RazePage的沉淀,虽然来得晚,但一经发布,就将Blazor推向了新的高度。从今年开始,Youtube上关于Blazor的优质教学视频,以肉眼可见的速度在增加,说明有更多人愿意学习和传播Blazor。Vue和Nuxt.js我都有在用,技术层面,我认为完全是可以去Battle一下的。大家不要停留在BlazorWebAssembly时代,现在Blazor对标的,是Next.js、Nuxt.js。
SSR的东西不多,但如果你像我一样没用过MVC,可能需要一些时间来理解它。如果是刚接触Blazor,我也建议从SSR开始,然后逐步开启BlazorServer、BlazorWebAssembly和Auto等多种渲染模式。

1、传统的请求响应模式

传统Web是经典的请求响应模式,客户端提交请求,服务端处理后,将HTML“整体”返回给客户端,客户端重新刷新“整个”页面,而且请求响应是无状态的,服务端分不清前后两次请求的区别。

2、JS开始介入请求响应过程

每次都请求整个HTML,并刷新整个页面,完全没有必要,因为很多时候,只需要刷新页面的部分数据,于是出现了Ajax。Ajax使用XMLHttpRequest对象,目前趋势是使用fetch。具体原理和过程,请看下一节,基本一样。

3、Blazor的SSR渲染

Blazor的SSR和Ajax基本一样,但有其特点:

  • 首次请求时,返回整体HTML、静态文件、JS脚本-blazor.web.js。其中重点是blazor.web.js,之后的请求和响应都由它来完成,包括响应用户交互事件->向服务器发送请求->处理服务器响应->将更新内容提交给DOM渲染而不需要整体重载页面。这种部分刷新的特性,Blazor称之为增强型导航
  • blazor.web.js内部使用了更加现代的fetch,而不是传统的XMLHttpRequest。Blazor对fetch进行了包装,我们不需要写任何fetch代码,正常使用Blazor语法就行,非常方便。
  • blazor.web.js除了完成请求响应之外,它还负责管理BlazorServer模式的SignalR连接,WebAssembly相关的JS脚本也在里面,以及Auto模式的管理,也靠它。
  • Blazor在这个技术路线上,进一步实现了流式渲染和增强型表单。这两个技术,应该是继承自MVC,MVC了解比较少,知道的朋友可以留言说说。多亏了MVC和RagePage,Blazor的SSR一经面世,就已经成熟可用。
  • 当然,SSR模式下的请求响应,也是无状态的


下图为首次打开页面,下载整个HTML、静态文件和blazor.web.js
image.png
下图为之后跳转路由,都是通过fetch发送请求。
image.png

4、在Blazor的SSR中,利用表单实现响应式数据

以下代码,虽然是SSR渲染,但利用了表单请求的特性,数据提交到服务器处理后可以返回,实现了响应式的经典案例。但这个方式只是奇技淫巧,只适合临时变通一下。如果有响应式数据需求,还是应该使用BlazorServer或者BlazorWasm。

//Enhance为增强型表单带来增强型导航功能,提交表单时,避免重载整个页面
//必须赋值FormName属性,表单数据在客户端和服务端传递时,这个是识别的ID
//要定义隐藏的InputNumber,来承接数据。通过Input将数据传送到服务器,处理后,再传回来。
<EditForm Enhance Model="SsrCounterModel" FormName="ssrCounterForm" OnSubmit="AddCount"><InputNumber @bind-Value="SsrCounterModel!.Num" hidden></InputNumber><p role="status">当前计数: @SsrCounterModel!.Num</p><button class="btn btn-primary" type="submit">增加</button></EditForm>@code {//表单绑定的Model,必须标注SupplyParameterFromForm特性[SupplyParameterFromForm]private SsrCounterModel? SsrCounterModel { get; set; }//在生命周期函数OnParametersSet中完成Model的初始化protected override void OnParametersSet(){SsrCounterModel ??= new SsrCounterModel { Num = 0 };}private void AddCount(){SsrCounterModel!.Num++;}
}

以上案例并不完善,如果快速点击按钮,会出现请求报错,日常开发,不鼓励使用这种方式来实现响应式数据。
image.png

5、总结

不晓得大家有没有深究过“交互式”这个概念,其中有一个特性就是部分更新。另外,我们还通过变通之计,在SSR模式下,实现了响应式数据。从这些角度看,如果有人说SSR也是交互式的,也不好反驳。其实,争论这些没有意义,Blazor这个从社区项目一步步成长起来的技术栈,能够成为AspNetCore的头牌实属不易。作为前端的后起之秀,相比主流框架,它仍然有距离,而C#和WebAssembly也为Blazor提供了很多JS框架所不具备的可能性,它能够玩的空间是非常多的。


关于Blazor渲染模式的分享,我会连续发几篇,大家持续关注交流,有问题评论区见~~~


我是functionMC > function MyClass(){…}
C#/TS/鸿蒙/AI/中美科技竞争等问题,以及如何写Bug、防脱发、送外卖等问题,都可以私信我提问哦!

相关文章:

  • 数据结构:3.3.4遍历应用例子
  • 达索系统基于模型的系统工程:开启创新与高效的新时代
  • Golang | Leetcode Golang题解之第145题二叉树的后序遍历
  • vmware workstation下centos7屏幕切换及大小调整
  • 计算机专业毕设-在线商城系统
  • 【源码】2024最新陪诊小程序uniapp+thinkphp
  • 在WordPress中使用AI的实用方法:入门级
  • 【名词解释】Unity中的3D物理系统:刚体
  • 企业级-封装Java对内卷PDF利用关键字分页导出标题
  • shell脚本监控docker容器和supervisor 运行情况
  • python-docx顺序读取word内容
  • 服务器主机托管服务内容科普
  • vscode连接ssh远程服务器
  • Jenkins 发测试邮件报错 553 Mail from must equal authorized user
  • SQL_CALC_FOUND_ROWS 和 FOUND_ROWS()实现对复杂sql实现分页与总条数查询
  • [分享]iOS开发 - 实现UITableView Plain SectionView和table不停留一起滑动
  • 10个确保微服务与容器安全的最佳实践
  • docker python 配置
  • ES6--对象的扩展
  • Fabric架构演变之路
  • JavaScript 一些 DOM 的知识点
  • js递归,无限分级树形折叠菜单
  • redis学习笔记(三):列表、集合、有序集合
  • SpiderData 2019年2月13日 DApp数据排行榜
  • webpack4 一点通
  • Webpack入门之遇到的那些坑,系列示例Demo
  • 包装类对象
  • 翻译:Hystrix - How To Use
  • 给初学者:JavaScript 中数组操作注意点
  • 基于Mobx的多页面小程序的全局共享状态管理实践
  • 解析带emoji和链接的聊天系统消息
  • 利用jquery编写加法运算验证码
  • 配置 PM2 实现代码自动发布
  • 前嗅ForeSpider教程:创建模板
  • 通过几道题目学习二叉搜索树
  • 温故知新之javascript面向对象
  • 用mpvue开发微信小程序
  • Prometheus VS InfluxDB
  • 我们雇佣了一只大猴子...
  • # Redis 入门到精通(一)数据类型(4)
  • #define,static,const,三种常量的区别
  • (35)远程识别(又称无人机识别)(二)
  • (6)【Python/机器学习/深度学习】Machine-Learning模型与算法应用—使用Adaboost建模及工作环境下的数据分析整理
  • (7) cmake 编译C++程序(二)
  • (Redis使用系列) SpringBoot中Redis的RedisConfig 二
  • (笔记自用)LeetCode:快乐数
  • (不用互三)AI绘画工具应该如何选择
  • (二)springcloud实战之config配置中心
  • (附源码)springboot 房产中介系统 毕业设计 312341
  • (含react-draggable库以及相关BUG如何解决)固定在左上方某盒子内(如按钮)添加可拖动功能,使用react hook语法实现
  • (论文阅读22/100)Learning a Deep Compact Image Representation for Visual Tracking
  • (十八)用JAVA编写MP3解码器——迷你播放器
  • (新)网络工程师考点串讲与真题详解
  • (原創) 是否该学PetShop将Model和BLL分开? (.NET) (N-Tier) (PetShop) (OO)
  • (转)eclipse内存溢出设置 -Xms212m -Xmx804m -XX:PermSize=250M -XX:MaxPermSize=356m