Django的生命周期流程图(补充)、路由层urls.py文件、无名分组和有名分组、反向解析(无名反向解析、有名反向解析)、路由分发、伪静态

news2025/1/17 5:59:48

一、orm的增删改查方法(补充)

1. 查询
	res=models.表名(类名).objects.all()[0]
    res=models.表名(类名).objects.filter(username=username, password=password).all()
    res = models.表名(类名).objects.first()  # 判断,判断数据是否有
    
    # res如果查询出来的是一条,直接就是对象
    # res它查询来的是多条,结果就是queryset对象 [对象,对象,对象]
    # 如果你使用的all查询的,就算查询一条数据,结果也是queryset对象 [对象,对象,对象]
    # 我们直接可以对queryset对象进行循环
2. 增加
	 # 第一种方式:
	res=models.表名(类名).objects.create(username='', password='')
    '''增加数据的时候也有返回结果:就是当前插入成功的数据对象''' # 可不是影响的行数
    res.username
    res.password
    # 第二种方式:
    obj = models.表名(类名)(username='', password='') 
    obj.save()
3. 更新
	res=models.表名(类名).objects.update(username='', password='') # 全表更新
    res=models.表名(类名).objects.filter().update(username='', password='')  
    '''返回的结果才是影响的行数'''
     # 第二种方式:
     # 先查询
    user_obj = models.表名(类名).objects.first()
    user_obj.username = username
    user_obj.save()
4. 删除
	models.表名(类名).objects.filter().delete() # 直接就删除了
    """删除的方式有两种类型"""
    1. 物理删除:直接把数据从磁盘中删除,.delete()方式就是直接物理删除
    2. 软删除: 软删除的意思是,不直接从硬盘中删数据,而是在表中在增加一个字段,一般叫is_delete
        它的用法就是,正常的数据这个字段的值为0,如果你要删除这条记录,is_Delete=1
        # 每次删除的时候,只需要更新这个字段就可以了
        id   username   password  age  gender is_delete
        1		1		1		1		1		0
        1		1		1		1		1		1
        1		1		1		1		1		0
        1		1		1		1		1		0
        1		1		1		1		1		0
        1		1		1		1		1		1
        # 查询的时候怎么区分是正常数据还是已经被删除的数据?
        models.表名(类名).objects.filter(is_delete=0).all()

二、ORM创建表关系(补充)

"""
	三种关系:
		一对一:一个作者能不能有多个作者详情信息,一个作者详情不能有多个作者。
		一对多:一本图书能不能有多个出版社,而多个出版社可以出版多本图书
		多对多:一个作者能写多本图书,一本图书能有多个作者来写。
"""
# 当你在创建表的时候,先创建基础字段,然后在考虑关系字段,外键字段

一对多:models.ForeignKey(to='被关联的表名', to_field='') # 默认是跟这个表的主键字段关联
多对多:models.ManytoManyField(to='被关联的表名', to_field='') # 默认是跟这个表的主键字段关联
一对一:models.OneToOneField(to='被关联的表名', to_field='') # 默认是跟这个表的主键字段关联

查询API

<1> all():                  查询所有结果
<2> filter(**kwargs):       它包含了与所给筛选条件相匹配的对象 
<3> get(**kwargs):          返回与所给筛选条件相匹配的对象,返回结果有且只有一个,
                            如果符合筛选条件的对象超过一个或者没有都会抛出错误。
  
<4> exclude(**kwargs):      它包含了与所给筛选条件不匹配的对象
<5> order_by(*field):       对查询结果排序('-id')
<6> reverse():              对且只对order_by排序的结果进行翻转
<8> count():                返回数据库中匹配查询(QuerySet)的对象数量。
<9> first():                返回QuerySet集中的第一个对象   
<10> last():                返回QuerySet集中的最后一个对象 
<11> exists():              如果QuerySet包含数据,就返回True,否则返回False
<12> values(*field):        返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列
                            model的实例化对象,而是一个可迭代的字典序列   
                                
<13> values_list(*field):   它与values()非常相似,但返回的是一个元组序列
<14> distinct():            从返回结果中剔除重复纪录


三、Django的生命周期流程图(补充)

1. 用户先从浏览器发起HTTP请求
2. 请求就来到了web服务器(web服务网关接口)
	socktet部分
    wsgiref模块实现的socket服务端
    """
    	1. 请求来的时候,把HTTP格式的数据封装打包成一个字典
    	2. 响应走的时候,把数据封装成符合HTTP格式的数据返回给浏览器
    """
    # 后面还给它改成uwsgi服务器
    # wsgiref、uwsgi他们两个也都会遵循一个协议:WSGI协议
    https://www.yuque.com/liyangqit/cbndkh/evyps8
3. Django应用
4. 中间件
5. 路由层
6. 视图层
7. 模板层
8. DB
"""混合项目:前端页面和Python代码都写在一个项目里面,前后端分离,前端是一个项目,后端是一个项目,中间通过json格式的数据进行数据传输"""

1.CGI

1、通用网关接口(Common Gateway Interface/CGI)是一种重要的互联网技术,可以让一个客户端,从网页浏览器向执行在网络服务器上的程序请求数据。CGI描述了服务器和请求处理程序之间传输数据的一种标准。
2、CGI程序可以用任何脚本语言或者是完全独立编程语言实现,只要这个语言可以在这个系统上运行。
3、用来规范web服务器传输到php解释器中的数据类型以及数据格式,包括URL、查询字符串、POST数据、HTTP header等,也就是为了保证web server传递过来的数据是标准格式的
4、一句话总结: 一个标准,定义了客户端服务器之间如何传数据

2.FastCGI

1、快速通用网关接口(Fast Common Gateway Interface/FastCGI)是一种让交互程序与Web服务器通信的协议。FastCGI是早期通用网关接口(CGI)的增强版本。
2、FastCGI致力于减少网页服务器与CGI程序之间互动的开销,从而使服务器可以同时处理更多的网页请求。
3、使用FastCGI的服务器:
    Apache HTTP Server (部分)
    Cherokee HTTP Server
    Hiawatha Webserver
    Lighttpd
    Nginx
    LiteSpeed Web Server
    Microsoft IIS
4、一句话总结: CGI的升级版

在这里插入图片描述

3.WSGI

1、Web服务器网关接口(Python Web Server Gateway Interface,缩写为WSGI)是为Python语言定义的Web服务器和Web应用程序或框架之间的一种简单而通用的接口。自从WSGI被开发出来以后,许多其它语言中也出现了类似接口。
2、wsgi server (比如uWSGI) 要和 wsgi application(比如django )交互,uwsgi需要将过来的请求转给django 处理,那么uWSGI 和 django的交互和调用就需要一个统一的规范,这个规范就是WSGI WSGI(Web Server Gateway Interface)
3、WSGI,全称 Web Server Gateway Interface,或者 Python Web Server Gateway Interface ,是为 Python 语言定义的 Web 服务器和 Web 应用程序或框架之间的一种简单而通用的接口。自从 WSGI 被开发出来以后,许多其它语言中也出现了类似接口。
4、WSGI 的官方定义是,the Python Web Server Gateway Interface。从名字就可以看出来,这东西是一个Gateway,也就是网关。网关的作用就是在协议之间进行转换。
5、WSGI 是作为 Web 服务器与 Web 应用程序或应用框架之间的一种低级别的接口,以提升可移植 Web 应用开发的共同点。WSGI 是基于现存的 CGI 标准而设计的
6、一句话总结: 为Python定义的web服务器和web框架之间的接口标准

4.uWSGI

wsgiref,werkzeug(一个是符合wsgi协议的web服务器+工具包(封装了一些东西))
uWSGI 用c语言写的,性能比较高
gunicorn:python写的
tornado:也可以部署django项目
1、它是一个Web服务器(类似的有wsgiref,gunicorn),它实现了WSGI协议、uwsgi、http等协议。用于接收前端服务器转发的动态请求并处理后发给 web 应用程序。
2、Nginx中HttpUwsgiModule的作用是与uWSGI服务器进行交换
3、一句话总结: 一个Web Server,即一个实现了WSGI的服务器,大体和Apache是一个类型的东西,处理发来的请求。 

在这里插入图片描述

5.uwsgi


location / {
	  #方式一
	  #include uwsgi_params; # 导入一个Nginx模块他是用来和uWSGI进行通讯的
	 	#uwsgi_connect_timeout 30; # 设置连接uWSGI超时时间
	  #uwsgi_pass 101.133.225.166:8080;
	  #方式二
	  #include uwsgi_params; # 导入一个Nginx模块他是用来和uWSGI进行通讯的
	  #uwsgi_pass unix:///var/www/script/uwsgi.sock; # 指定uwsgi的sock文件所有动态请求
	  #方式三
	  proxy_pass http://101.133.225.166:8088
}


它是uWSGI服务器实现的独有的协议,用于定义传输信息的类型,是用于前端服务器与 uwsgi 的通信规范。
一句话总结: uWSGI自有的一个协议
uWSGI:web服务器,等同于wsgiref
uwsgi:uWSGI自有的协议

在这里插入图片描述
在这里插入图片描述

四、路由层urls.py文件

  • url函数的使用(支持正则表达式)
  • 无名分组
  • 有名分组
  • 反向解析
    • 无名分组反向解析
    • 有名分组反向解析
  • 路由分发
  • 伪静态的概念
  • 虚拟环境(纯净版的解释器)
  • 视图层
    • 每个视图函数都要返回HttpResponse对象、render、redirect
    • 序列化(JsonResponse对象、drf中会有专门的序列化文件)
    • form表单如何上传文件
    • CBV(class based view)和FBV(function based view)
    • CBV的源码分析
    • 面试题:你看过Django的哪些源码?
    • 频率、权限、认证等的源码

五、url函数的使用(支持正则表达式)

# django1中使用的是url


url(r'^admin/', admin.site.urls),  # 默认的路由地址,它是django自带的后台管理系统

url('test', views.test),
url函数的第一个参数是支持正则表达式的
如果匹配到一个路由,就不再往下匹配,直接执行路由对应的视图函数

# http://127.0.0.1:8000/test/
是django默认设置的,django会先拿着test去匹配,如果匹配不到,它会自动加一个斜杠再次去匹配

# 缓存:redis数据库缓存
APPEND_SLASH = False  # 不加斜杠匹配, 默认的是 APPEND_SLASH = True
 
# django2中使用的是path
path('test/', admin.site.urls), # path是不支持正则的,它是精准匹配,输入的内容和路由地址必须是完全匹配
re_path('^test/$', admin.site.urls) # django1中的url是完全一样的

六、无名分组

分组:在正则表达式中使用小括号括起来的内容就是分组
	单独的分组其实是没有意义的,它不影响我们的正常匹配
	re模块中的分组优先原则 re.match()
	先把分组的内容显示出来

url('^test/(\d+)/(\d+)$', views.test),
def test(request, xx, yy):
    print(xx, yy) # 123
    return HttpResponse("test")

注意:无名分组就是把路由地址匹配的的数据以位置参数的形式传递给视图函数

七、有名分组

分组:在正则表达式中使用小括号括起来的内容然后给它起个名字就是有名分组
url('^testadd/(?P<year>\d+)/(?P<month>\d+)$', views.testadd)

注意:有名分组就是把路由地址匹配的的数据以关键字参数的形式传递给视图函数

# 这种形式也是第二种传参方式
http://127.0.0.1:8000/testadd/123/11
http://127.0.0.1:8000/testadd/?a=1&b=2

        
注意:1.有名分组和无名分组能否一起使用?
	不要一起使用

	2.但是无名或者有名单独的可以使用多次
url('^testadd/(?P<year>\d+)/(?P<month>\d+)/(?P<month>\d+)/(?P<month>\d+)$', views.testadd)


def testadd(request, year, month):
    print('testadd')
    print(year)
    print(year)
    return HttpResponse('testadd')


url('^test/(\d+)/(\d+)/(\d+)/(\d+)/(\d+)/(\d+)/(\d+)$', views.test),

django2中的用法:用法和django1一样
re_path('^test/(\d+)/(\d+)/(\d+)/(\d+)/(\d+)/(\d+)/(\d+)$', views.test),
re_path('^testadd/(?P<year>\d+)/(?P<month>\d+)/(?P<month>\d+)/(?P<month>\d+)$', views.testadd)

八、反向解析


1.反向解析:  意思是可以给路由起一个名字,然后通过一个方法可以解析出这个名字对应的路由地址

url('^testadd/(?P<year>\d+)/(?P<month>\d+)$', views.testadd, name='testadd') # name路由名字

2.后端解析
后端反向解析
print(reverse('test'))  # /test/  /test/v1/  /test/v1/v2

3.前端解析 {% url '待匹配的名字' %}
<a href="{% url 'test' %}">点我</a>

九、无名分组反向解析

1.前端解析
<a href="{% url 'test' 111 %}">点我</a>

2.后端解析
print(reverse('test', args=(123, )))  # /test/1  /test/123

问题:这个参数到底指定几或者说指定给谁?
reverse('test', args=(123, ))

十、有名分组反向解析

1.前端解析
<a href="{% url 'testadd' 2023 12 %}">点我</a>

2.后端解析
print(reverse('testadd',kwargs={'year':2023, 'month':12}))  # /testadd/2023  /testadd/2023/12

十一、django2中的path函数支持的5种转换器

path('test/', admin.site.urls)
Django默认支持以下5个转化器:

● str,匹配除了路径分隔符(/)之外的非空字符串,这是默认的形式
● int,匹配正整数,包含0。
● slug,匹配字母、数字以及横杠、下划线组成的字符串。
● uuid,匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00。
● path,匹配任何非空字符串,包含了路径分隔符(/)(不能用?)

urlpatterns = [  
    path('articles/2003/', views.special_case_2003),  
    path('articles/<int:year>/', views.year_archive),  
    path('articles/<int:year>/<int:month>/', views.month_archive),  
    path('articles/<int:year>/<int:month>/<slug>/', views.article_detail),  
  # path才支持,re_path不支持
  path('order/<int:year>',views.order),
]


十二、路由分发

# 目前一个django项目只有一个总路由文件urls.py
# 但是当我们的路由比较多的时候,这个文件就会产生很多的路由地址,产生的问题就是理由比较臃肿,不太容易管理,也不太容易排查错误

我们针对每一个应用也可以有自己的路由文件,每一个应用下的路由我们称之为是子路由
但是你会发现每一个应用下面没有urls.py这个文件
我们需要自己手动创建出来一个文件

'''这个时候产生了很多的路由文件,匹配的时候先匹配总路由,然后有总路由进行分发到每个子路由'''
# 这个时候总路由的作用就是分发了,总路由就不再执行具体的视图函数,而是交给子路由

1.第一种方式:
# url('^app01/', include(app01_urls)),
# url('^app02/', include(app02_urls)),

2.第二种方式
url('^app01/$', include('app01.urls')),
url('^app02/$', include('app02.urls')),

"""
	总路由中的路由分发地址后面一定不能加$
"""

十三、伪静态的概念

# 静态文件 .html
index.html

http://127.0.0.1:8000/app01/index
https://www.cnblogs.com/fanshaoO/p/17592993.html # 其实就是伪静态之后的地址
原本这个地址是动态的,数据是从数据库中查询出来的,而不是在html页面中写死的

为什么要伪静态呢?
"""
	作用就是让搜索引擎增大seo的查询力度,言外之意就是让我们的页面能够更加容易的被搜索引擎搜索出来
"""
# 比如你在百度中搜索一个关键词,百度的搜索引擎就会去全网搜索数据
# 其实搜索引擎(百度、谷歌、bing、等)就是一个巨大的爬虫程序

因为静态的页面更加容易被搜索引擎抓到,这个称之为是seo
seo就是优化你们的产品能够被更容易的搜多到

SEO---------------------->一般是通过技术手段等实现
SEM---------------------->它是需要收费的,其实就是广告

十四、虚拟环境

# 一般我们开发项目是一个单独的项目使用一个单独的解释器环境
举例:
开发一个CRM系统:3.6
开发一个OA系统:3.7
开发一个商城系统:3.6

难道我们每一个项目都使用一个解释器吗? 肯定不是
每个项目单独使用一个解释器版本,这个解释器中只安装这个项目使用到的模块

注意1:每开发一个项目我就下载一个解释器,当然能够解决问题,都是这样做吗?
	我们会使用虚拟环境来解决这个问题
	虚拟环境其实就是一个纯净版本的解释器,不用每次都下载和安装
	它就是一个文件夹形式存在的解释器

注意2:虚拟环境尽量不要创建,创建出来够你的项目使用就行了

注意3:虚拟环境还可以通过命令创建

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/817706.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何通过github学生包认证(远程不在学校或在校但位置报错均可用)

如何通过github学生包认证 在经历11次被拒绝&#xff0c;查阅多方博客后&#xff0c;终于成功通过了github的学生认证&#xff0c;材料每次重复的话github又会让你提交不同的材料&#xff0c;博主最后都已经要没有材料可以证明自己是学生了&#xff0c;不得不说这个认证是真的…

git使用(由浅到深)

目录流程图 1. 分布式版本控制与集中式版本控制 1.1 集中式版本控制 集中式版本控制系统有:CVS和SVN它们的主要特点是单一的集中管理的服务器&#xff0c;保存所有文件的修订版本&#xff1b;协同开发人员通过客户端连接到这台服务器&#xff0c;取出最新的文件或者提交更新…

【C++】通讯录管理系统

1.系统功能介绍与展示 2.创建项目 3.菜单功能 代码&#xff1a; //-封装函数显示该界面 如 void showMenu() //-在main函数中调用封装好的函数 #include <iostream> using namespace std;//-菜单界面 void showMenu() {cout << "***************************…

Azure pipeline自动化打包发布

pipeline自动化&#xff0c;提交代码后&#xff0c;就自动打包&#xff0c;打包成功后自动发布 第一步 pipeline提交代码后&#xff0c;自动打包。 1 在Repos,分支里选择要触发的分支&#xff0c;这里选择cn_china,对该分支设置分支策略 2 在生产验证中增加新的策略 3 在分支安…

【Linux】yum工具的认识及使用

【Linux】yum工具的认识及使用 1.知识点补充2.yum是什么3.yum常用指令3.1查看软件安装包3.1.1关于rzsz 3.2安装软件3.3卸载软件 4.yum扩展4.1扩展14.2扩展24.3扩展3 什么是工具&#xff1f; 本质上也是指令 1.知识点补充 1.我们一般安装软件&#xff0c;是不是需要把软件安装…

LabVIEW FPGA开发实时滑动摩擦系统

LabVIEW FPGA开发实时滑动摩擦系统 由于非线性摩擦效应的建模和补偿的固有困难&#xff0c;摩擦系统的运动控制已被广泛研究。最近&#xff0c;人们更加关注滑动动力学和滑动定位&#xff0c;作为传统机器人定位的低成本和更灵活的驱动替代方案。摩擦控制器设计和适当选择基础…

JVM类加载器的作用和层次结构

类加载器的作用 1)通过一个类的全限定名来获取定义此类的二进制字节流。 2)将这个字节流所代表的静态存储结构转化为方法区的运行时数据结构。 3)在内存中生成一个代表这个类的java.lang.Class对象,这个对象存放在方法区中。这个对象将作为程序访问方法区中的这些数据的外部接…

【嵌入式学习笔记】嵌入式入门2——中断(外部中断)

1.什么是中断 打断CPU执行正常的程序&#xff0c;转而处理紧急程序&#xff0c;然后返回原暂停的程序继续运行&#xff0c;就叫中断 1.1.中断的作用与意义 作用1&#xff1a;实时控制在确定时间内对相应事件作出响应——定时器中断作用2&#xff1a;故障处理检测到故障&…

Linux内核的I2C驱动框架详解------这应该是我目前600多篇博客中耗时最长的一篇博客

目录 1 I2C驱动整体框架图 2 I2C控制器 2.1 I2C控制器设备--I2C控制器在内核中也被看做一个设备 2.2 i2c控制器驱动程序 2.3 platform_driver结构体中的probe函数做了什么 2.3.1 疑问&#xff1a; i2cdev_notifier_call函数哪里来的 2.3.2 疑问&#xff1a;为什么有两…

重生之我要学C++第六天

这篇文章的主要内容是const以及权限问题、static关键字、友元函数和友元类&#xff0c;希望对大家有所帮助&#xff0c;点赞收藏评论支持一下吧&#xff01; 更多优质内容跳转&#xff1a; 专栏&#xff1a;重生之C启程(文章平均质量分93) 目录 const以及权限问题 1.const修饰…

管理类联考——数学——可视化篇——代数即几何

数形结合百般好 代数即几何 两和三个数的完全平方和 https://www.bilibili.com/video/BV1zh4y137AY/ 立方差和立方和公式 通过图形得到立方差公式&#xff0c;将b换成-b&#xff0c;得到立方和公式 平方数列求和 https://www.bilibili.com/video/BV1vz4y1q75D/ 立方数列…

[PAT乙级] 1029 旧键盘 C++实现

题目描述&#xff1a; 旧键盘上坏了几个键&#xff0c;于是在敲一段文字的时候&#xff0c;对应的字符就不会出现。现在给出应该输入的一段文字、以及实际被输入的文字&#xff0c;请你列出肯定坏掉的那些键。 输入格式&#xff1a; 输入在 2 行中分别给出应该输入的文字、以…

基于高通QCC5171的对讲机音频数据传输系统设计

一 研发资料准备 二 设计方法 蓝牙连接与配对&#xff1a;使用QCC5171的蓝牙功能&#xff0c;实现设备之间的蓝牙连接和配对。确保设备能够相互识别并建立起稳定的蓝牙连接。 音频采集与处理&#xff1a;将麦克风采集到的音频数据通过QCC5171的ADC&#xff08;模数转换器&…

简单的知识图谱可视化+绘制nx.Graph()时报错TypeError: ‘_AxesStack‘ object is not callable

绘制nx.Graph时报错TypeError: _AxesStack object is not callable 写在最前面知识图谱可视化预期报错可能的原因 原代码原因确认解决后的代码解决&#xff01; 写在最前面 实现一个简单的知识图谱的可视化功能。 使用了NetworkX库来构建知识图谱&#xff0c;并使用matplotlib…

【面试题】 给你十万条数据,怎么样顺滑的渲染出来?

前端面试题库 &#xff08;面试必备&#xff09; 推荐&#xff1a;★★★★★ 地址&#xff1a;前端面试题库 前言 这是一道面试题&#xff0c;这个问题出来的一刹那&#xff0c;很容易想到的就是for循环100000次吧&#xff0c;但是这方案着实让浏览器崩溃啊&…

基于LoRa无线数据传输的温湿度监测预警系统解决方案

为了维护仓储物品的品质&#xff0c;创造适宜的存储环境&#xff0c;就需要实时监测环境的温湿度信息&#xff0c;一旦温湿度出现异常就需要及时调整控制&#xff0c;从而保证品质稳定也能避免损失。 物通博联提供了软硬件一体的工业物联网解决方案&#xff0c;基于温湿度监测…

2023年超越期待的高性能视频剪辑主机推荐| Intel 蝰蛇峡谷测评

1、开箱 蝰蛇峡谷的开箱体验是非常令人兴奋的。首先&#xff0c;打开包装后&#xff0c;你会看到一个精致且高质感的机箱&#xff0c;给人一种专业的感觉。蝰蛇峡谷的外观设计简洁大方&#xff0c;黑色的机箱与红色的Logo相得益彰&#xff0c;展现了其高性能的特点。 在打开机…

文件上传到远程服务器

文件上传 一、上传文件到本地 package com.ruoyi.system.knowledgebase;import com.ruoyi.common.annotation.Anonymous; import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.system.domain.SzKnowledge; import com.ruoyi.system.service.ISzKnowledgeServi…

MyBatis缓存-提高检索效率的利器--二级缓存

文章目录 缓存-提高检索效率的利器缓存-官方文档二级缓存基本介绍二级缓存原理图 二级缓存快速入门快速入门注意事项和使用陷阱理解二级缓存策略的参数 四大策略如何禁用二级缓存mybatis 刷新二级缓存的设置 缓存-提高检索效率的利器 缓存-官方文档 文档地址: https://mybati…

低代码平台实际解决了哪些问题?

一、前言 目前低代码平台如火如荼。这一新兴技术为企业提供了一种高效、灵活、快速开发应用程序的方法&#xff0c;并在短时间内取得了巨大成功。然而&#xff0c;我们不得不面对低代码平台的优劣以及其所带来的挑战。本文将深入探讨低代码平台在不同情况下的优劣势&#xff0c…