前言

日常, 我的开发都围绕着 ASP.NET Core 和 Angular. 这篇想聊聊它们各自的特点和解决问题的方式.

以及最重要的, 我们该在什么时候采用何种方案更为妥当.

浅谈项目分类

我一般会把项目分 4 种来看待

1. Web 1.0 时代的网站

比如企业网站. 这类网站的目的是 present information. 用户行为是游览 + 少量的交互.

游览就是一页一页的. 所谓的 multipl pages

交互分两种

一种是 "show more 交互". 网页设计有一个 "渐进式阅读” 的原则. 你不要一上来就给我一堆的内容, 我要先过一遍, 感兴趣的才深入阅读.

于是网页就出现了许多 hidding information. 当用户感兴趣时就通过交互展开这些内容.

比如: slider, accordion, tabs

另一种交互是 "provide data 交互". 用户想提交一些数据给站长.

比如像订阅就需要提供 Email, 想联系站长需要提供, name, contact, message 等等.

2. Web 2.0 时代的网站

Web 1.0 的特色是, 网页内容都是由站长提供的. 而 Web 2.0 则多了一个提供方. 那就是用户.

比如, 电子商务网站.

register > add to cart > order > payment. 这些都是用户修改了网站信息. 这在 1.0 是没有的.

3. Web Application

Web Application 指的是利用 Web 技术 (HTML, JS, CSS) 做出来的应用程序.

网站和 Application 应用程序的区别是

App 强调在 "用", 网站则是偏 "看"

我们拿一家卖产品的公司来举例.

step 1: start from 企业网站, present company profile and product catelog, 用户来 “看”, 有兴趣就联络 submit enquiry form (Web 1.0)

step 2 : upgrade to 电子商务网站, 用户 "看" > 注册 > add to cart > make order > payment (Web 2.0)

step 3 : upgrade to Web Application, 交互流程没有变, 只是提升了交互体验 (PWA 了解一下)

step 4 : upgrade to mobile app, web app 受技术限制, 体验不会比原生 mobile app 好. 所以要想再提升就要用 mobile app 了.

整个过程就是需求和体验的升级, 从开始的 "看" + "enquiry form" 到后来的 "register > add to cart > order > payment", 用户需要做的事情越来越多.

4. 后台管理系统 (control panel)

不管是 CMS, CRM, ERP 都算是管理系统.

你可以把它看成是 "一种" Web Application. 但我会把它独立出来.

浅谈 ASP.NET Core

ASP.NET Core 主要有 2 种用法

1. Razor Pages / MVC 适用于开发网站

2. Web API 适用于开发 API server (前后台分家)

开发网站

网站有分很多种, 比如 企业网站, 电商网站, 博客网站, 社交平台等等.

精确的话 ASP.NET Core Razor Pages 方案比较适合开发 Web 1.0 年代的网站. 比如企业网站 (就是那种以游览为主, 很少交互的网站)

原因我后面会说, 先聊聊网站访问流程和开发分工.

网站访问流程

一般网站访问流程大致是这样的

step 1: browser request web page from server

step 2 : server 从数据库获取数据

step 3 : server 把数据和 HTML 模板做结合 (binding)

step 4 : server 返回 HTML

step 5 : 用户交互

step 6 : browser 通过 form post 或者 ajax 发 request 到 server

step 7 : server 返回 HTML 或者 JSON

step 8 : browser 刷新或者局部刷新

网站开发分工

后端负责 ASP.NET Core 和 Database, 前端负责 HTML, CSS, JS.

ASP.NET Core 的强与弱

step 2, 3, 4 是 ASP.NET Core 主要发力的地方. (这部分都是偏 "游览“)

step 5 - 8 则是偏 "交互", 除了 form submit + reload page 和 server 处理 ajax 并返回 JSON 以外, 其余的部分 ASP.NET Core 几乎是一点忙都帮不上的.

于是, 当网站需要越多交互体验的时候, 采用 ASP.NET Core 开发就会越吃力.

网站开发 – 分工

ASP.NET Core 的开发人员是属于后端开发人员. 上面 8 个 step 只有 binding 模板/form 需要一点点的前端知识

其余的地方完全不需要. 所以常见的分工方式是一个. 前端负责 HTML, CSS, 其余的都交给 ASP.NET Core 开发人员.

binding 模板的部分双方配合一下或者让 ASP.NET Core 的开发人员学一点简单的 HTML 就可以了

2. 微软本身就没有要提升这部分.

重交互的网站, JS 必然重. 一旦 JS 重你就必须要搞一个前端开发. TS, Sass, Bundle 那一套就来了.

Angular 16+ 高级教程 – 谈谈 ASP.NET Core & Angular & React 在业务开发上各自的优势和体验的更多相关文章

  1. C# 6 与 .NET Core 1.0 高级编程 - 40 ASP.NET Core(上)

    译文,个人原创,转载请注明出处(C# 6 与 .NET Core 1.0 高级编程 - 40 章  ASP.NET Core(上)),不对的地方欢迎指出与交流. 章节出自<Professiona ...

  2. C# 6 与 .NET Core 1.0 高级编程 - 40 ASP.NET Core(下)

    译文,个人原创,转载请注明出处(C# 6 与 .NET Core 1.0 高级编程 - 40 章  ASP.NET Core(下)),不对的地方欢迎指出与交流. 章节出自<Professiona ...

  3. 52abp框架asp.net core & Angular快速开发实战视频教程

    课程标题 52abp框架asp.net core & Angular全栈开发实战视频课程 课程简介 从零开始学 52ABP企业开发框架,企业项目是如何开发和技术选型,代码如何管理,团队协同开发 ...

  4. ASP.NET Core 基础教程总结 - ASP.NET Core 基础教程 - 简单教程,简单编程

    原文:ASP.NET Core 基础教程总结 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 基础教程总结 ASP.NET Core 基础教程总算是有了个简单 ...

  5. ASP.NET Core 基础教程-约定 - ASP.NET Core 基础教程 - 简单教程,简单编程

    原文:ASP.NET Core 基础教程-约定 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 基础教程-约定 因为 ASP.NET Core 是可以跨平台的 ...

  6. [ASP.NET Core 3框架揭秘] 跨平台开发体验: Linux

    如果想体验Linux环境下开发.NET Core应用,我们有多种选择.一种就是在一台物理机上安装原生的Linux,我们可以根据自身的喜好选择某种Linux Distribution,目前来说像RHEL ...

  7. 翻译 - ASP.NET Core 托管和部署 - 在 Linux 上使用 Nginx 托管 ASP.NET Core 网站

    翻译自 https://docs.microsoft.com/en-us/aspnet/core/host-and-deploy/linux-nginx?view=aspnetcore-5.0 本文介 ...

  8. ASP.NET Core 简单实现七牛图片上传(FormData 和 Base64)

    ASP.NET Core 简单实现七牛图片上传(FormData 和 Base64) 七牛图片上传 SDK(.NET 版本):https://developer.qiniu.com/kodo/sdk/ ...

  9. 从零开始实现ASP.NET Core MVC的插件式开发(一) - 使用ApplicationPart动态加载控制器和视图

    标题:从零开始实现ASP.NET Core MVC的插件式开发(一) - 使用Application Part动态加载控制器和视图 作者:Lamond Lu 地址:http://www.cnblogs ...

  10. 从零开始实现ASP.NET Core MVC的插件式开发(二) - 如何创建项目模板

    标题:从零开始实现ASP.NET Core MVC的插件式开发(二) - 如何创建项目模板 作者:Lamond Lu 地址:https://www.cnblogs.com/lwqlun/p/11155 ...

随机推荐

  1. 当项目中使用到缓存,我们是选择 Redis 还是 Memcached ,为什么?

    举一些场景: 一.比如实现一个简单的日志收集功能或发送大量短信.邮件的功能,实现方式是先将数据收集到队列中,然后有一个定时任务去消耗队列,处理该做的事情. 直接使用 Redis 的 lpush,rpo ...

  2. oeasy教您玩转vim - 1 - # 存活下来 🥊

    存活下来 更新 apt 源,升级 vim vim 是什么 vim 是类 unix 系统上的一个文本编辑神器,在 Linux 系统环境中也被许多程序员使用,书写程序和文档. 我们本次课程将围绕 Vim ...

  3. [oeasy]python0024_ 输出时间_time_模块_module_函数_function

    ​ 输出时间 回忆上次内容 ​print​​函数 有个默认的 ​​end参数​ ​​end参数​​ 的值可以是任意字符串 ​​end参数​​ 的值会输出到结尾位置 ​​end参数​​ 的默认值是 ​​ ...

  4. EasyDesktop 浏览器书签管理从未如此简单

    作为一名软件开发从业人员, 每天80%的时间都在与浏览器打交道, 一半的时间在用浏览器开发调试, 另一半时间则是在互联网上搜寻各种知识和资源. 为此, 我的浏览器书签栏存储和很多非常棒的链接, 多到2 ...

  5. 个人使用 sudo 方法

    sudo 作用:允许 系统管理员 授予某些用户或用户组以 其他用户身份 运行某些或所有命令的权限 su 用于变更为其他使用者的身份的命令,一般需要键入该使用者的密码 sudo 则是对 su 使用的简化 ...

  6. SUM-ACM——VJ天梯训练赛

    这次比赛我暴露了很多问题,一些模拟还有贪心思路错误. 补题如下: E - E 题解:一道模拟题,我的问题在于不知道怎么替换下一个,就从0开始遍历数组然后数组的值--,如果为零就continue下一个, ...

  7. 关于elementUI的select组件回显问题

    最近接受了一个后台项目,需求是这样的,点击表单项,弹出的弹出层显示该表单项目的信息.但是回显的时候,关于弹出层中的级联显示有问题,如图: 回显结果为: 回显代码为: 弹框为: 我就不明白了,分明分公司 ...

  8. Spring Boot快速入门(二)搭建javaWeb项目

    1.配置pom.xml 教程一创建的项目为maven项目,所以搭建一个Spring Boot的Web项目,先导入一下jar包:即在pom.xml以下依赖: 1 <dependencies> ...

  9. mybatis源码分析:插件是什么

    在上篇文章中,<mybatis源码配置文件解析之四:解析plugins标签 >分析了mybatis中的plugin标签的解析过程,plugin指的是插件,或者说拦截器更为形象,因为它的作用 ...

  10. redis如何实现主从同步

    redis实现主从同步分为两种:全量同步和增量同步:第一次连入集群的slave需要进行全量同步,那些断开后重连的slave需要进行增量同步 每个redis都有自己的replid,他们是master的标 ...