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

MarkDown中写UML图的方法

目录

  • UML图之顺序图
    • 顺序图的四个要素
    • 关于消息箭头的语法
    • Mermaid中顺序图的简单例子
      • 样例
      • 用小人表示对象
      • 为对象设置别名
      • 激活对象
  • UML图之类图
    • 类图中常见的关系
    • 关于不同类型关系的语法
    • Mermaid中类图的简单例子
      • 样例
      • 类定义的两种方式
      • 为类定义成员
      • 双向关系的表示
      • 多重性关系的表示
  • UML之状态图
    • 状态图的构成要素
    • Mermaid中顺序图的简单例子
      • 样例
      • 状态的表示
      • 转移的表示
      • 开始和结束的表示
      • 判断的表示
      • 同步的表示

Mermaid(中译为美人鱼,就好比一条美人鱼在流动构成了各种的图),是一种在MarkDown中以特定格式的文字生成各种图示的方法。

接着之前写过的MarkDown中写流程图的方法这篇博客,经过了三年,Mermaid也是接连更新了软件工程中常用的顺序图、类图、状态图等UML图,E-R图以及项目管理中常用的甘特图、饼图,还有常用版本管理工具Git的合并策略图也可以画出来了!这真是为开发者们徒增不少便利啊!

只有你想不到,没有Mermaid做不到,当然这不是打广告!就连思维导图Mermaid也支持啦!虽然XMind用来画思维导图是更加方便的,不过多掌握一项技能又何尝不可呢!

这篇博客将为大家介绍如何绘制常见UML图,诸如顺序图、类图、状态图。

UML图之顺序图

顺序图又叫时序图、序列图,即以时间为主线,有生命线的动态视图,它显示了各个进程之间是如何运作的,以及它们是以什么顺序运作的。

顺序图的四个要素

对象:类的实例化。

生命线:对象存在的时间。

消息:对象之间靠消息传递信息和指令,用从一个对象的生命线到另一个对象生命线的箭头表示消息。

激活:这个时间,对象可以实现操作。对象存在时生命线用一条虚线表示,当对象的过程处于激活状态,生命线用双道线表示。

接下来介绍如何使用Mermaid画顺序图。

关于消息箭头的语法

消息箭头类型表达含义示意图
->不带箭头的实线/
-->不带箭头的点虚线/
->>带箭头的实线在这里插入图片描述
-->>带箭头的点虚线在这里插入图片描述
-x尾部带十字叉的实线在这里插入图片描述
--x尾部带十字叉的点虚线在这里插入图片描述
-)尾部是开箭头的实线(异步)在这里插入图片描述
--)尾部是开箭头的点虚线(异步)在这里插入图片描述

Mermaid中顺序图的简单例子

样例

在下面这段文字(代码块中)的前面和后面一行各自添加```(键盘左上,与~共用一个键)即可生成如下图的展示结果(注意在使用时需要增加mermaid标识,加在前面那三点的后面)。

sequenceDiagram学生->>老师: 老师,请问这道题的解题思路是什么?老师-->>学生: 来,你看这边,是这样的……学生-)老师: 醍醐灌顶!谢谢老师!!
学生老师老师,请问这道题的解题思路是什么?来,你看这边,是这样的……醍醐灌顶!谢谢老师!!学生老师

注意:end这个词会与Mermaid语法冲突,如果必须要使用到,需将这样使用:(end) [ end ] { end }.

用小人表示对象

上面的例子是用长方形和文字来表示一个对象的,如果要用更加形象的小人来表示对象,那么在使用对象前,用actor来声明即可。

sequenceDiagramactor 学生actor 老师学生->>老师: 老师好!老师-->>学生: 你好~
学生老师老师好!你好~学生老师

为对象设置别名

如果觉得对象名太长太复杂,那么可以使用participant···as···的语法为对象名设置一个简要的别名。

sequenceDiagramparticipant A as 学生participant B as 老师A->>B: 老师好!B-->>A: 你好~
学生老师老师好!你好~学生老师

这样画出来的图没有区别,但是写法上会简单很多。

激活对象

如果想要激活对象,那么使用activate;取消对象的激活状态,则使用deactivate

sequenceDiagramactor A as 学生actor B as 系统A->>B: 录入信息activate BB-->>A: 更新信息deactivate B
学生系统录入信息更新信息学生系统

可以使用+/-简化激活/未激活状态。

sequenceDiagramactor A as 学生actor B as 系统A->>+B: 录入信息B-->>-A: 更新信息
学生系统录入信息更新信息学生系统

UML图之类图

在面向对象的模型中,类图常用来表达系统的类、属性、操作(又叫方法)以及类之间的关系。

类图中常见的关系

泛化(Generalization):一种继承关系,即一般与特殊的关系,它指定了子类如何特化父类的所有特征和行为。
表示:带三角箭头的实线,箭头指向父类。

实现(Realization):一种类与接口的关系,即类是接口所有特征和行为的实现。
表示:带三角箭头的虚线,箭头指向接口。

关联(Association):一种拥有关系,它使一个类知道另一个类的属性和方法。
表示:带普通箭头的实心线,指向被拥有者。

聚合(Aggregation):整体与部分的关系,且部分可以离开整体而单独存在。
注:聚合关系是关联关系的一种,是强的关联关系;关联和聚合在语义上无法区分,必须考察具体的逻辑关系。
表示:带空心菱形的实心线,菱形指向整体。

组合(Composition):整体与部分的关系,但部分不能离开整体而单独存在。
注:组合关系也是关联关系的一种,但相比于聚合,组合是一种更强的关联关系。
表示:带实心菱形的实线,菱形指向整体。

依赖(Dependency):一种使用的关系,即一个类的实现需要另一个类的协助,因此尽量不要使用双向的互相依赖。
表示:带箭头的虚线,指向被使用者。

各种关系的强弱顺序:
泛化 = 实现 > 组合 > 聚合 > 关联 > 依赖

关于不同类型关系的语法

关系表达含义示意图
<|--继承/
*--组合/
o--聚合/
-->关联/
--实线连接/
..>依赖/
..|>实现/
..虚线连接/

Mermaid中类图的简单例子

样例

在下面这段文字(代码块中)的前面和后面一行各自添加```(键盘左上,与~共用一个键)即可生成如下图的展示结果(注意在使用时需要增加mermaid标识,加在前面那三点的后面)。

	classDiagram动物 ..< 水动物 ..< 氧气动物 <|-- 鸟鸟 <|-- 老鹰鸟 <|-- 白鹭鸟 <|-- 天鹅鸟 "1"*-->"2" 翅膀天鹅群"1"o-->"n"天鹅天鹅..|>飞翔白鹭"1"-->"1"气候动物: + 生命动物: + 性别动物: +新陈代谢(int 氧气,int 水)动物: +繁衍后代()飞翔: +飞()class 鸟{+羽毛+进食()+下蛋()}class 老鹰{-鹰眼视力-抓田鼠()-下蛋()}class 白鹭{+野生自然+捕鱼()+下蛋()}class 天鹅{+黑色与白色+捕鱼()+下蛋()}
1
2
1
n
1
1
动物
+ 生命
+ 性别
+新陈代谢(int 氧气,int 水)
+繁衍后代()
氧气
+羽毛
+进食()
+下蛋()
老鹰
-鹰眼视力
-抓田鼠()
-下蛋()
白鹭
+野生自然
+捕鱼()
+下蛋()
天鹅
+黑色与白色
+捕鱼()
+下蛋()
翅膀
天鹅群
飞翔
+飞()
气候

类定义的两种方式

  1. 使用关键词class来定义一个类。
    class Animal可以定义一个Animal的类:
classDiagramclass Animal
Animal
  1. 通过两个类之间的关系可以同时定义两个类。
    Vehicle <|-- Car表示Car类继承自Vehicle类:
classDiagramVehicle <|-- Car
Vehicle
Car

需要注意的是,类名应该只由字母、数字、字符(包括Unicode)和下划线组成。

为类定义成员

类通常有其特有的属性和方法,方法用到的参数通常在后面用()括起来。

而属性与方法的访问级别修饰符表示通常在冒号后面用一个符号来表示,对应的关系如下表所示:

符号访问级别修饰符
+Public
-Private
#Protected
~Package/Internal

如果想表示抽象方法或者是静态方法或静态变量,可以分别使用*$符号标明:

  • 抽象方法:someAbstractMethod()*
  • 静态方法:someStaticMethod()$
  • 静态变量:String someField$

同样的,有两种方法来定义类的成员:

  1. 在类后面使用:,冒号后面跟类成员。这种方式适用于一次定义一个成员。
classDiagram
class Person
Person: +String name
Person: +int age
Person: +work(time) bool
Person: +study(time) int
Person
+String name
+int age
+work(time) : bool
+study(time) : int
  1. 使用{}将类成员括起来。这种方式适用于一次定义多个成员。
classDiagram
class Person{+String name+int age+work(time) bool+study(time) int
}
Person
+String name
+int age
+work(time) : bool
+study(time) : int

注:如果方法有返回值,那么返回值类型可以在方法后加一个空格并加上其返回值类型。

如果成员变量中含有泛型,那么像List<int>是这样表示的:List~int~。即使用了~ ~来表示了< >

classDiagram
class Square~Shape~{int idList~int~ positionsetPoints(List~int~ points)getPoints() List~int~
}Square : +List~string~ messages
Square : +setMessages(List~string~ messages)
Square : +getMessages() List~string~
Square : +getDistanceMatrix() List~List~int~~
Square<Shape>
int id
List<int> position
+List<string> messages
setPoints(List<int> points)
getPoints() : List<int>
+setMessages(List<string> messages)
+getMessages() : List<string>
+getDistanceMatrix()

双向关系的表示

关系可以表示逻辑上N:M的联系。
一个简单的例子如下:

classDiagramAnimal <|--|> Zebra
Animal
Zebra

双向关系的语法格式:

[关系类型][连接][关系类型]

其中关系类型如下表所示:

关系类型说明
<|继承
\*组合
o聚合
>关联
<关联
|>实现

其中连接如下表所示:

连接类型说明
--实线
..虚线

多重性关系的表示

类图中的多重性或者叫基数表示一个类有多少实例可以与另一个类的实例形成关系。

不同的基数表示方法:

  • 1:一个
  • 0..1:零个或一个
  • 1..*:一个或多个
  • *:零个或多个
  • n:n个
  • 0..n:零到n个
  • 1..n:一到n个

基数可以在箭头表示的关系左右加上引号和以上的基数表示:

classDiagramCustomer "1" --> "*" TicketStudent "1" --> "1..*" CourseGalaxy --> "many" Star : Contains
1
*
1
1..*
n
Customer
Ticket
Student
Course
Galaxy
Star

UML之状态图

状态图主要用于描述一个特定的对象的所有可能状态以及由于各种事件的发生而引起的状态之间的转换。

状态图的构成要素

  • 状态(States):在对象的生命周期中满足某些条件、执行某些活动或等待某些事件的一个条件或状况。所有的对象都有状态,状态是对象执行了一系列活动的结果,当某个事件发生后,对象的状态将发生变化。
    状态图中可以包含0个多个开始状态,也可以包含多个结束状态。模型不必同时具有开始和结束状态,因为模型可以总是运行,从不停止。
  • 转移(Transitions):两个状态之间的一种关系,表示对象将在第一个状态中执行一定的动作并在某个特定事件发生或某个特定条件满足时进入第二个状态。
StateA
StateB
  • 事件:使状态发生变化的某时刻发生的动作或活动,用来指示是什么触发了转移从而导致状态发生了改变。事件通常在从一个状态到另一个状态的转移路径上直接指定。
  • 判断:判断点通过对事件判断分组转移到各自方向,提高了状态图的可视性。
StateA
StateB
StateC
StateD
  • 同步:使用同步和活动图一样是为了说明并发工作流的分叉与联合。
StateA
StateB

注:状态图重点在与描述对象的状态及其状态之间的转移,与活动图区别在于状态图注重的是行为的结果,活动图更注重是行为的动作。

Mermaid中顺序图的简单例子

样例

在下面这段文字(代码块中)的前面和后面一行各自添加```(键盘左上,与~共用一个键)即可生成如下图的展示结果(注意在使用时需要增加mermaid标识,加在前面那三点的后面)。

stateDiagram[*] --> 用户登录用户登录 --> 登录成功:验证通过登录成功 --> 填写信息:注册新卡填写信息 --> 存入数据库:信息合理存入数据库--> 提示成功:保存成功提示成功 --> 退出系统:退出退出系统-->[*]
验证通过
注册新卡
信息合理
保存成功
退出
用户登录
登录成功
填写信息
存入数据库
提示成功
退出系统

状态的表示

状态的表示有多种方式:

  1. 最简单的是用一个名字来定义一个状态:
stateDiagram-v2stateId
stateId
  1. 如果要简写状态名,则可以使用以下方式:
stateDiagram-v2state "StateA" as s1s1 -->StateB
StateA
StateB

这样在后续就可以直接使用s1来表示StateA了。
3. 简写状态名还可以用冒号的方式:

stateDiagram-v2s1 : StateAs1 -->StateB
StateA
StateB

转移的表示

转移使用箭头-->表示。
当在两个状态间定义一个转移时,这两个状态也同时会被定义。

stateDiagram-v2s1 --> s2
s1
s2

如果想在转移上添加文字,那么在后面加上一个冒号后写上想添加的文字即可。

stateDiagram-v2s1 --> s2: A transition
A transition
s1
s2

开始和结束的表示

在状态图中,开始和结束状态是两个特殊的状态。它们都用[*]来表示。

stateDiagram-v2[*] --> s1s1 --> [*]
s1

判断的表示

如果状态图中涉及到了判断,那么可以使用<<choice>>来表示。

stateDiagram-v2state if_state <<choice>>[*] --> IsPositiveIsPositive --> if_stateif_state --> False: if n < 0if_state --> True : if n >= 0
if n < 0
if n >= 0
IsPositive
False
True

同步的表示

对于同步的表示,则使用到了<<fork>><<join>>

stateDiagram-v2state fork_state <<fork>>[*] --> fork_statefork_state --> State2fork_state --> State3state join_state <<join>>State2 --> join_stateState3 --> join_statejoin_state --> State4State4 --> [*]
State2
State3
State4

相关文章:

MarkDown中写UML图的方法

目录序UML图之顺序图顺序图的四个要素关于消息箭头的语法Mermaid中顺序图的简单例子样例用小人表示对象为对象设置别名激活对象UML图之类图类图中常见的关系关于不同类型关系的语法Mermaid中类图的简单例子样例类定义的两种方式为类定义成员双向关系的表示多重性关系的表示UML之…...

Axure8设计—动态仪表盘

本次分享的的案例是Axure8制作的动态仪表盘,根据设置的数值&#xff0c;仪表盘指针旋转到相应的值位置 预览地址&#xff1a;https://2qiuwg.axshare.com 下载地址&#xff1a;https://download.csdn.net/download/weixin_43516258/87502161 一、制作原型 1、首先创建空白页…...

【C++】类和对象的六个默认成员函数

类的6个默认成员函数构造函数概念特性析构函数概念特性拷贝构造函数概念特征拷贝构造函数典型调用场景&#xff1a;赋值运算符重载运算符重载赋值运算符重载取地址及const取地址操作符重载类的6个默认成员函数 到底什么是类的6个默认成员函数呢&#xff1f;相信大家一定对此怀…...

4、算法MATLAB---认识矩阵

认识矩阵1、矩阵定义和基本运算1.1 赋值运算符&#xff1a;1.2 等号运算符&#xff1a;1.3 空矩阵1.4 一行一列矩阵1.5 行矩阵&#xff08;元素用空格或逗号分隔&#xff09;1.6 列矩阵&#xff08;分号表示换行&#xff09;1.7 m行n列的矩阵&#xff1a;行值用逗号间隔&#x…...

vue3+rust个人博客建站日记2-确定需求

反思 有人说过我们正在临近代码的终结点。很快&#xff0c;代码就会自动产生出来&#xff0c;不需要再人工编写。程序员完全没用了&#xff0c;因为商务人士可以从规约直接生成程序。 扯淡&#xff01;我们永远抛不掉代码&#xff0c;因为代码呈现了需求的细节。在某些层面上&a…...

Linux安装云原生网关Kong/KongA

目录1 概述2 创建服务器3 安装postgres4 安装kong5 安装node6 安装KONGA1 概述 Kong Kong是一款基于OpenResty&#xff08;NginxLua模块&#xff09;编写的高可用、易扩展的开源API网关&#xff0c;专为云原生和云混合架构而建&#xff0c;并针对微服务和分布式架构进行了特别…...

Vue学习笔记(2)

2.1 事件处理 2.1.1 事件监听器 JavaScript&#xff1a;通过获取DOM对象再往DOM对象上使用addEventListener注册监听事件 const btn document.querySelector(#my-button) btn.addEventListener(click, function() {alert(点击事件!) })jQuery&#xff1a;通过$选择器绑定对象…...

2023年三月份图形化四级打卡试题

活动时间 从2023年3月1日至3月21日&#xff0c;每天一道编程题。 本次打卡的规则如下&#xff1a; 小朋友每天利用10~15分钟做一道编程题&#xff0c;遇到问题就来群内讨论&#xff0c;我来给大家答疑。 小朋友做完题目后&#xff0c;截图到朋友圈打卡并把打卡的截图发到活动群…...

Python操作Excel

Python中对Excel文件的操作包括&#xff1a;读、写、修改。如果要对其进行如上的操作需要导入Python的第三方模块&#xff1a;xlrd、xlwd、xlutils&#xff0c;其分别对应Python的读、写、修改的操作 一、安装Python的第三方模块 二、操作Excel的基本步骤 1、导入响对应的模…...

Codeforces Round #853 (Div. 2) C. Serval and Toxel‘s Arrays【统计次数,算贡献】

链接 传送门 分析 这道题想法其实很简单&#xff0c;样例的计算方法一定要看懂。以样例1为例&#xff0c;根据他的操作方法可以得到两个新的数组&#xff0c;和一个原来的数组&#xff0c;总共三个数组。 1 2 3 4 2 3 4 5 3 他们两两配对去重&#xff0c;求出总的value。由于每…...

微信小程序-1:比较两数的大小

程序来源》微信小程序开发教程&#xff08;第二章&#xff09; 主编&#xff1a;黄寿孟、易芳、陶延涛 ISBN&#xff1a; 9787566720788 程序运行结果&#xff1a; <!--index.wxml--> <view class"container"> <text>第一个数字&#xff1a;&…...

数据结构——树

深度优先/广度优先遍历深度优先&#xff1a;访问根节点对根节点的 children 挨个进行深度优先遍历const tree {val: "a",children: [{val: "b",children: [{val: "d",children: [],},{val: "e",children: [],},],},{val: "c&quo…...

【华为OD机试模拟题】用 C++ 实现 - 找到它(2023.Q1)

最近更新的博客 【华为OD机试模拟题】用 C++ 实现 - 去重求和(2023.Q1) 文章目录 最近更新的博客使用说明找到它题目输入输出示例一输入输出示例二输入输出说明Code使用说明 参加华为od机试,一定要注意不要完全背诵代码,需要理解之后模仿写出,通过率才会高。 华为 OD …...

python中yield的使用

在 Python 中&#xff0c;yield 是一个关键字&#xff0c;它用于定义生成器函数。生成器函数是一个特殊的函数&#xff0c;可以返回一个迭代器&#xff0c;当生成器函数被调用时&#xff0c;它不会立即执行&#xff0c;而是返回一个生成器对象&#xff0c;通过迭代生成器对象可…...

GO进阶(4) 深入Go的内存管理

Go语言成为高生产力语言的原因之一自己管理内存&#xff1a;Go抛弃了C/C中的开发者管理内存的方式&#xff0c;实现了主动申请与主动释放管理&#xff0c;增加了逃逸分析和GC&#xff0c;将开发者从内存管理中释放出来&#xff0c;让开发者有更多的精力去关注软件设计&#xff…...

【C++】类与对象理解和学习(下)

放在专栏【C知识总结】&#xff0c;会持续更新&#xff0c;期待支持&#x1f339;建议先看完【C】类与对象理解和学习&#xff08;上&#xff09;【C】类与对象理解和学习&#xff08;中&#xff09;本章知识点概括Ⅰ本章知识点概括Ⅱ初始化列表前言在上一篇文章中&#xff0c;…...

【Neo4j】Spring Data Neo4j APi阅读随笔

引言 关于Spring boot整合Neo4j的官方api翻译&学习随笔 (TOC) 一、准备工作 1.注入依赖 <dependency><groupId>org.springframework.data</groupId><artifactId>spring-data-jpa</artifactId></dependency>2.配置yml文件 这里是本…...

JVM内存模型简介

1 程序计数器 程序计数器是一块较小的内存空间&#xff0c;可以看作是当前线程所执行的字节码的行号指示器。字节码解释器工作时通过改变这个计数器的值来选取下一条需要执行的字节码指令&#xff0c;分支、循环、跳转、异常处理、线程恢复等功能都需要依赖这个计数器来完。 ja…...

k8s如何给node添加标签

一、为什么需要标签&#xff1f; k8s集群如果由大量节点组成&#xff0c;可将节点打上对应的标签&#xff0c;然后通过标签进行筛选及查看,更好的进行资源对象的相关选择与匹配 二、怎么查看目前node上具有的标签 [rootmaster01 ~]# kubectl get node --show-labels NAME …...

【大数据Hive】Hive ddl语法使用详解

一、前言 使用过关系型数据库mysql的同学对mysql的ddl语法应该不陌生&#xff0c;使用ddl语言来创建数据库中的表、索引、视图、存储过程、触发器等&#xff0c;hive中也提供了类似ddl的语法。本篇将详细讲述hive中ddl的使用。 二、hive - ddl 整体概述 在Hive中&#xff0c;DA…...

调用支付宝接口响应40004 SYSTEM_ERROR问题排查

在对接支付宝API的时候&#xff0c;遇到了一些问题&#xff0c;记录一下排查过程。 Body:{"datadigital_fincloud_generalsaas_face_certify_initialize_response":{"msg":"Business Failed","code":"40004","sub_msg…...

云计算——弹性云计算器(ECS)

弹性云服务器&#xff1a;ECS 概述 云计算重构了ICT系统&#xff0c;云计算平台厂商推出使得厂家能够主要关注应用管理而非平台管理的云平台&#xff0c;包含如下主要概念。 ECS&#xff08;Elastic Cloud Server&#xff09;&#xff1a;即弹性云服务器&#xff0c;是云计算…...

Opencv中的addweighted函数

一.addweighted函数作用 addweighted&#xff08;&#xff09;是OpenCV库中用于图像处理的函数&#xff0c;主要功能是将两个输入图像&#xff08;尺寸和类型相同&#xff09;按照指定的权重进行加权叠加&#xff08;图像融合&#xff09;&#xff0c;并添加一个标量值&#x…...

MVC 数据库

MVC 数据库 引言 在软件开发领域,Model-View-Controller(MVC)是一种流行的软件架构模式,它将应用程序分为三个核心组件:模型(Model)、视图(View)和控制器(Controller)。这种模式有助于提高代码的可维护性和可扩展性。本文将深入探讨MVC架构与数据库之间的关系,以…...

Cinnamon修改面板小工具图标

Cinnamon开始菜单-CSDN博客 设置模块都是做好的&#xff0c;比GNOME简单得多&#xff01; 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...

Ascend NPU上适配Step-Audio模型

1 概述 1.1 简述 Step-Audio 是业界首个集语音理解与生成控制一体化的产品级开源实时语音对话系统&#xff0c;支持多语言对话&#xff08;如 中文&#xff0c;英文&#xff0c;日语&#xff09;&#xff0c;语音情感&#xff08;如 开心&#xff0c;悲伤&#xff09;&#x…...

全志A40i android7.1 调试信息打印串口由uart0改为uart3

一&#xff0c;概述 1. 目的 将调试信息打印串口由uart0改为uart3。 2. 版本信息 Uboot版本&#xff1a;2014.07&#xff1b; Kernel版本&#xff1a;Linux-3.10&#xff1b; 二&#xff0c;Uboot 1. sys_config.fex改动 使能uart3(TX:PH00 RX:PH01)&#xff0c;并让boo…...

Android 之 kotlin 语言学习笔记三(Kotlin-Java 互操作)

参考官方文档&#xff1a;https://developer.android.google.cn/kotlin/interop?hlzh-cn 一、Java&#xff08;供 Kotlin 使用&#xff09; 1、不得使用硬关键字 不要使用 Kotlin 的任何硬关键字作为方法的名称 或字段。允许使用 Kotlin 的软关键字、修饰符关键字和特殊标识…...

在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?

uni-app 中 Web-view 与 Vue 页面的通讯机制详解 一、Web-view 简介 Web-view 是 uni-app 提供的一个重要组件&#xff0c;用于在原生应用中加载 HTML 页面&#xff1a; 支持加载本地 HTML 文件支持加载远程 HTML 页面实现 Web 与原生的双向通讯可用于嵌入第三方网页或 H5 应…...

安全突围:重塑内生安全体系:齐向东在2025年BCS大会的演讲

文章目录 前言第一部分&#xff1a;体系力量是突围之钥第一重困境是体系思想落地不畅。第二重困境是大小体系融合瓶颈。第三重困境是“小体系”运营梗阻。 第二部分&#xff1a;体系矛盾是突围之障一是数据孤岛的障碍。二是投入不足的障碍。三是新旧兼容难的障碍。 第三部分&am…...