vue2语法-简略版

 内容不全,发现看官方文档效果更好。

介绍 — Vue.js

API — Vue.js

二、Vue指令

2.1 内容渲染指令 v-text,v-html

内容渲染指令用来辅助开发者渲染DOM元素的文本内容,常用的内容渲染指令有如下2个:

  • v-text(类似innerText)

使用语法:<p v-text="uname">hello</p>,意思是将uname值渲染到p标签中
类似innerText,使用该语法,会覆盖p标签原有内容

  • v-html(类似innerHTML)

使用语法:<p v-html="intro">hello</p>,意思是将intro值渲染到p标签中
类似innerHTML,使用该语法,会覆盖p标签原有内容,能够将HTML标签的样式呈现出来

2.2 条件渲染指令 v-show,v-if,v-else,v-else-if

条件判断指令,用来辅助开发者按需控制DOM的显示与隐藏。条件渲染指令有如下两个,分别是:

  • v-show

作用:控制元素显示隐藏
语法:v-show=“表达式” 表达式值为true显示,false隐藏
原理:切换display:none控制显示隐藏
场景:频繁切换显示隐藏的场景

  • v-if

作用:控制元素显示隐藏
语法:v-if=“表达式” 表达式值为true显示,false隐藏
原理:基于条件判断,是否创建或移除元素节点
场景:要么显示,要么隐藏,不频繁切换的场景

2.3 事件绑定指令 v-on (@)

为DOM注册事件,语法如下:

  • <button v-on:事件名=“内联语句”>按钮
  • <button v-on:事件名=“处理函数”>按钮
  • <button v-on:事件名=“处理函数(实参)”>按钮
  • v-on 简写为 @
  • v-on:click 可以缩写为 @click,其中@代表v-on:
2.4 属性绑定指令 v-bind (:)
  • 作用:动态设置html的标签属性,比如:src、url、title
  • 语法:v-bind:属性名=“表达式”
  • v-bind 缩写为 :
  • v-bind:href 可以缩写为 :href
2.5 v-bind对样式控制的增强
2.5.1 操作class

为了方便开发者进行样式控制,Vue扩展了v-bind的语法,可以针对class类名和style行内样式进行控制。

语法

  • 普通形式:

<div> :class = "对象/数组">这是一个div</div>
  • 对象语法: 
<div class="box" :class="{ 类名1: 布尔值, 类名2: 布尔值 }"></div>

当class动态绑定的是对象时,键就是类名,值就是布尔值,如果值是true,就有这个类,否则没有这个类

适用场景:一个类名来回切换

  • 数组语法:
<div class="box" :class="[ 类名1, 类名2, 类名3 ]"></div>

当class动态绑定的是数组时,数组中所有的类都会添加到盒子上,本质就是一个class列表

使用场景:批量添加或删除类

2.5.2 切换高亮
li a.active {background-color: #e01222;color: #fff;
}
<body><div id="app"><ul><li v-for="(item,index) in list" :key="item.id" @click="activeIndex=index"><a :class="{active:index==activeIndex?true:false}" href="#">{{item.name}}</a></li></ul></div><script src="./vue.js"></script><script>const app = new Vue({el: '#app',data: {activeIndex: 0,list: [{ id: 1, name: '京东秒杀' },{ id: 2, name: '每日特价' },{ id: 3, name: '品类秒杀' }]}})</script>
</body>
2.5.3 操作style
<div class="box" :style="{ CSS属性名1: CSS属性值, CSS属性名2: CSS属性值 }"></div>

2.6 列表渲染指令

Vue提供了v-for列表渲染指令,用来辅助开发者基于一个数组来循环渲染一个列表结构。

v-for指令需要使用(item , index) in arr形式的特殊语法,其中:

  • item是数组中的每一项
  • index是每一项的索引,不需要可以省略
  • arr是被遍历的数组
2.6.1 v-for中的key

语法:key=“唯一值”

作用:给列表项添加唯一的标识。便于Vue进行列表项的正确排序复用

为什么加key:Vue的默认行为会尝试原地修改元素(就地复用

注意:

  1. key的值只能是字符串或数字类型
  2. key的值必须具有唯一性
  3. 推荐使用id作为key(唯一),不推荐使用index作为key(会变化,不对应)
2.9 双向绑定指令 v-model

所谓双向绑定就是:

  1. 数据改变后,呈现的页面结果会更新
  2. 页面结果更新后,数据也会随之改变

语法:v-model=“变量”

作用:给表单元素(input、radio、select)使用,双向绑定数据,可以快速获取或设置表单元素内容

2.10 v-model在其它表单元素的使用

常见的表单元素都可以用v-model绑定关联,快速获取或设置表单元素的值

它会根据控件类型自动选取正确的方法来更新元素

输入框 input:text ——> value
文本域 textarea ——> value
复选框 input:checkbox ——> checked
单选框 input:radio ——> checked
下拉菜单 select ——> value

<div id="app"><h3>小黑学习网</h3>姓名:<input type="text" v-model="username"><br><br>是否单身:<input type="checkbox" v-model="isSingle"><br><br><!-- 前置理解:1. name:  给单选框加上 name 属性 可以分组 → 同一组互相会互斥2. value: 给单选框加上 value 属性,用于提交给后台的数据结合 Vue 使用 → v-model-->性别:<input v-model="gender" type="radio" name="gender" value="1">男<input v-model="gender" type="radio" name="gender" value="2">女<br><br><!-- 前置理解:1. option 需要设置 value 值,提交给后台2. select 的 value 值,关联了选中的 option 的 value 值结合 Vue 使用 → v-model-->所在城市:<select v-model="city"><option value="101">北京</option><option value="102">上海</option><option value="103">成都</option><option value="104">南京</option></select><br><br>自我描述:<textarea v-model="desc"></textarea><button>立即注册</button></div><script src="./vue.js"></script><script>const app = new Vue({el: '#app',data: {username: '',isSingle: false,gender: 1,city: '102',desc: "暂无"}})</script>
2.11 指令修饰符

什么是指令修饰符?

所谓指令修饰符就是通过“.”指明一些指令后缀,不同的后缀封装了不同的处理操作 ->简化代码

按键修饰符

  • @keyup.enter:当点击enter键的时候才触发

v-model修饰符

  • v-model.trim:去除首位空格
  • v-model.number:转数字

事件修饰符

  • @事件名.stop:阻止冒泡
  • @事件名.prevent:阻止默认行为
  • @事件名.stop.prevent:可以连用,即阻止事件冒泡也阻止默认行为

三、computed与methods属性

3.1基础语法

computed概念

基于现有的数据,计算出来的新属性。依赖的数据变化,自动重新计算。

3.2 computed计算属性 VS methods方法

computed计算属性

作用:封装了一段对于数据的处理,求得一个结果

methods计算属性
作用:给Vue实例提供一个方法,调用以处理业务逻辑

总结

  1. computed有缓存特性,methods没有缓存
  2. 当一个结果依赖其他多个值时,推荐使用计算属性
  3. 当处理业务逻辑时,推荐使用methods方法,比如事件的处理函数
3.3 计算属性的完整写法

计算属性默认的简写,只能读取访问,不能“修改”,如果要修改,需要写计算属性的完整写法。

四、watch侦听器(监听器)

4.1 基础语法

作用:

监视数据变化,执行一些业务逻辑或异步操作

语法:

  • watch同样声明在跟data同级的配置项中
  • 简单写法:简单类型数据直接监视
  • 完整写法:添加额外配置项
data: { words: '苹果',obj: {words: '苹果'}
},watch: {// 该方法会在数据变化时,触发执行数据属性名 (newValue, oldValue) {一些业务逻辑 或 异步操作。 },'对象.属性名' (newValue, oldValue) {一些业务逻辑 或 异步操作。 }
}
4.3 完整写法

语法

完整写法,添加额外的配置项

  • deep:true 对复杂类型进行深度监听
  • immediate:true 初始化立即执行一次
<template><div><!-- 条件选择框 --><div class="query"><span>翻译成的语言:</span><select  v-model="obj.lang"><option value="italy">意大利</option><option value="english">英语</option><option value="german">德语</option></select></div><!-- 翻译框 --><div class="box"><div class="input-wrap"><span><i>⌨️</i>文档翻译</span></div><div class="input-wrap"><textarea v-model="obj.words"></textarea></div><div class="Qinput-wrap"><textarea v-model="words"></textarea></div><div class="output-wrap"><div class="transbox">{{result}}</div></div></div></div>
</template><script>export default {data() {return {words:'',obj: {words: '',lang: 'english',},result: '',//翻译结果timer: null//延时器i}},watch: {// //该方法在数据变化时调用执行// words(newValue, oldValue) {//   console.log("", newValue, oldValue)//   clearTimeout(this.timer)//   this.timer = setTimeout(async () => {//     var num = newValue.length + 101;//     this.result = Math.floor(Math.random() * num);//   }, 300)// },// 'obj.words'(newValue) {//   //防抖:延迟执行//   clearTimeout(this.timer)//   this.timer = setTimeout(async () => {//     var num = newValue.length + 101;//     this.result = Math.floor(Math.random() * num);//   }, 300)// },words: {handler(newValue, oldValue) {console.log("words handler", newValue, oldValue)clearTimeout(this.timer)this.timer = setTimeout(async () => {var num = newValue.length + 101;this.result = Math.floor(Math.random() * num);}, 300)},immediate: true,},obj: {deep: true, immediate: true,handler(newValue, oldValue) {console.log("1:", newValue, oldValue)clearTimeout(this.timer)this.timer = setTimeout(async () => {var num = newValue.words.length + 101;this.result = Math.floor(Math.random() * num);}, 300)}},},}
</script>

九、组件

9.1 组件的三大组成部分
9.1.1 scoped解决样式冲突

默认情况写在组件中的样式会全局生效,因此很容易造成多个组件之间的样式冲突问题。

  • 全局样式:默认组件中的样式会作用到全局,任何一个组件中都会受到此样式的影响。
  • 局部样式:可以给组件加上scoped属性,可以让样式只作用于当前组件。
<style scoped></style>
9.1.2 data必须是一个函数

一个组件的data选项必须是一个函数。目的是为了:保证每个组件实例,维护独立的一份数据对象。

每次创建新的组件实例,都会执行一次data函数,得到一个新对象。

<script>
export default {data: function () {return {count: 100,}},
}
</script>
9.2组件通信
9.2.1父子通信

什么是组件通信

组件通信,就是指组件与组件之间的数据传递

  • 组件的数据是独立的,无法直接访问其他组件的数据。
  • 想使用其他组件的数据,就需要组件通信

组件关系分类

  • 父子关系
  • 非父子关系

通信解决方案

父子关系:props 和 $emit

非父子关系:provide & inject 和 eventbus

通用解决方案:Vuex

父子通信流程

  • 父组件通过props将数据传递给子组件
  • 子组件利用$emit通知父组件修改更新

父向子传值步骤

  1. 给子组件以添加属性的方式传值
  2. 子组件内部通过props接收
  3. 模板中直接使用props接收的值

子向父传值步骤

  1. $emit触发事件,给父组件发送消息通知
  2. 父组件监听$emit触发的事件
  3. 提供处理函数,在函数的形参中获取传过来的参数

9.2.2 props
9.2.2.1 什么是props

props是组件上注册的一些自定义属性

可以向子组件传递数据

特点:

  • 可以传递任意数量的prop
  • 可以传递任意类型的prop
9.2.2.2 props校验

作用:为组件的prop指定验证要求,不符合要求,控制台就会有错误提示,帮助开发者快速发现错误

语法:

  • 类型校验
  • 非空校验
  • 默认值
  • 自定义校验
9.2.2.3 props校验完整写法
props: {校验的属性名: {type: 类型,  // Number String Boolean ...required: true, // 是否必填default: 默认值, // 默认值validator (value) {// 自定义校验逻辑return 是否通过校验}}
},
9.2.2.4 props和data、单向数据流

共同点:都可以给组件提供数据

区别:

  • data的数据是自己的,可以随便改
  • prop的数据是外部的,不能直接改,要遵循单向数据流

单向数据流:父级props的数据更新,会向下流动,影响子组件。这个数据流动是单向的

9.2.3非父子通信 略
9.2.3.1 event bus事件总线 略

9.2.3.2  provide&inject 略

十、进阶语法

10.1 v-model原理

作用

提供数据的双向绑定

  • 数据变,视图跟着变 :value
  • 视图变,数据跟着变 @input

语法

v-model本质上是一个语法糖。例如应用在输入框上,就是value属性和input事件的合写

<template><div id="app" ><input v-model="msg" type="text"><input       :value="msg"     @input="msg = $event.target.value" type="text"><input v-bind:value="msg" v-on:input="msg = $event.target.value" type="text"></div>
</template>

注意

$event用于在模板中,获取事件的形参

:model是Element属性

:model相当于v-bind:model的缩写—— 对model属性 绑定对应的data

10.2 v-model简化代码

目标

父组件通过v-model简化代码,实现子组件和父组件数据双向绑定

如何简化

v-model其实就是:value和@input事件的简写

  • 子组件:props通过value接收数据,事件触发input
  • 父组件:v-model直接绑定数据

父组件

<BaseSelect v-model="selectId"></BaseSelect>

子组件

<select :value="value" @change="handleChange">...</select>
props: {value: String
},
methods: {handleChange (e) {this.$emit('input', e.target.value)}
}

10.3 表单类组件封装

需求目标

实现子组件和父组件数据的双向绑定

App.vue

<template><div class="app"><BaseSelect :cityId="selectId" @changeId="selectId = $event"></BaseSelect></div>
</template><script>
import BaseSelect from './components/BaseSelect.vue'
export default {data() {return {selectId: '102',}},components: {BaseSelect,}
}
</script><style></style>

BaseSelect.vue

<template><div><select :value="cityId" @change="handleChange"><option value="101">北京</option><option value="102">上海</option><option value="103">武汉</option><option value="104">广州</option><option value="105">深圳</option></select></div>
</template><script>
export default {props: {cityId: String},methods: {handleChange(e) {this.$emit('changeId', e.target.value)}}
}
</script><style></style>
10.4 .sync修饰符

作用

可以实现子组件与父组件数据的双向绑定,简化代码

简单理解:子组件可以修改父组件传过来的props值

场景

封装弹框类的基础组件,visible属性true显示false隐藏

本质

.sync修饰符就是 :属性名 和 @update:属性名 合写

语法

父组件

//.sync写法
<BaseDialog :visible.sync="isShow" />
--------------------------------------
//完整写法
<BaseDialog :visible="isShow" @update:visible="isShow = $event" />

子组件

props: {visible: Boolean
},this.$emit('update:visible', false)
10.5 ref 和 $refs

作用

利用 ref 和 $refs 可以用于获取dom元素或组件实例

特点

查找范围在当前组件内(更精确稳定)

10.5.1 获取dom语法
  • 给要获取的盒子添加ref属性

<div ref="mychart" class="base-chart-box">子组件</div>
  • 获取时通过$refs获取

const myChart = echarts.init(this.$refs.mychart)

注意

之前只用document.querySelect(‘.base-chart-box’)获取的是整个页面中的盒子

10.5.2 获取组件语法
  • 目标组件添加ref属性
<BaseForm ref="baseForm"></BaseForm>
  • 恰当时机,通过this.$refs.xxx,获取目标组件,就可以调用组件对象里面的方法
this.$refs.baseForm.组件方法()
10.6 异步更新、&nextTick

需求

编辑标题,编辑框自动聚焦

  1. 点击编辑,显示编辑框    2 .让编辑框立刻获取焦点

问题

“显示之后”,立刻获取焦点是不能成功的     原因:Vue是异步更新DOM(提升性能)

解决方案

$nextTick : 等DOM更新后,才会触发执行此方法里的函数体

this.$nextTick(() => {this.$refs.inp.focus()
})

十一、自定义指令 略

十二、插槽

12.1 默认插槽

作用

让组件内部的一些结构支持自定义

语法

使用slot

<template><div><slot></slot></div>
</template>

<template><div><AppSon>slot中显示内容</AppSon></div>
</template>

显示效果

12.3 具名插槽

作用

多个slot使用name属性区分名字

语法

v-slot简写

v-slot写起来太长,vue给我们提供了一个简单写法 #

在vue2.6.0之前使用slot="插槽名"定义。

<template><div><slot name="head">默认数据</slot><slot name="content"></slot><slot name="footer"></slot></div>
</template>

<template><div><AppSon ><template v-slot:head>slot head中显示内容</template><template v-slot:content>slot content中显示内容</template><template v-slot:footer>slot footer中显示内容</template></AppSon>
--------------------------<AppSon ><template #head>slot head中显示内容</template><template #content>slot content中显示内容</template><template #footer>slot footer中显示内容</template></AppSon>
--------------------------<AppSon ><template #head></template><template #content>slot content中显示内容</template><template #footer>slot footer中显示内容</template></AppSon></div>
</template>

显示效果

12.4 作用域插槽 略

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

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

相关文章

项目进展(十一)--重新绘制ADS1285采集板并学习

声明&#xff1a;本人水平有限&#xff0c;博客可能存在部分错误的地方&#xff0c;请广大读者谅解并向本人反馈错误。   由于项目的需要&#xff0c;上周又设计了ADS1285的采集电路板&#xff0c;最近几天焊接了一下&#xff0c;重新进行测试。由于之前对ADC采集不是重点&am…

UDP数据报套接字编程

1.1UDP编程原理 对于UDP协议来说&#xff0c;具有无连接&#xff0c;面向数据报的特征&#xff0c;即每次都是没有建立连接&#xff0c;并且一次发送全部数据报&#xff0c;一次接收全部的数据报。Java中使用UDP协议通信&#xff0c;主要基于DatagramSocket类来发送或接收数据报…

C++:菱形继承与虚继承

看下面这个示例代码 class A{ public: int num10; A(){cout<<"A构造"<<endl;} virtual void fun(){cout<<"A虚函数"<<endl;} };class B:public A{ public: B(){cout<<"B构造"<<endl;} void fun(){cout<…

可视化图表:南丁格尔玫瑰图,来自历史上最著名的护士。

Hi&#xff0c;我是贝格前端工场的老司机&#xff0c;本文分享可视化图表设计的南丁格尔玫瑰图设计&#xff0c;欢迎老铁持续关注我们。 一、南丁格尔与玫瑰图 南丁格尔&#xff08;Florence Nightingale&#xff0c;1820年-1910年&#xff09;是一位英国护士和统计学家&…

按位操作符详解

大家好啊&#xff0c;我是情谊&#xff0c;今天我们来讨论一下按位操作符的知识点与应用&#xff0c;按位操作符有时候在解决一些问题的时候可以提供一个很好的解题思路&#xff0c;话不多说&#xff0c;我们直接来看&#xff01; 今天我们主要是从两个方面来讲述一下按位操作…

Redis:使用redis-dump导出、导入、还原数据实例

redis的备份和还原&#xff0c;借助了第三方的工具&#xff0c;redis-dump 1、安装必要环境 yum -y install zlib-devel openssl-devel2、安装redis-dump 安装ruby&#xff1a; ruby下载地址&#xff1a;https://www.ruby-lang.org/zh_cn/downloads/ 我下载的是 2.5.0 版本…

动态规划课堂6-----回文串问题

目录 引言&#xff1a; 例题1&#xff1a;回文子串 例题2&#xff1a;回文串分割IV 例题3&#xff1a;分割回文串II 例题4&#xff1a;最长回文子序列 例题5&#xff1a;让字符串成为回文串的最小插入次数 引言&#xff1a; 回文字符串 是正着读和倒过来读一样的字符串。…

【周赛】第385场周赛

&#x1f525;博客主页&#xff1a; A_SHOWY&#x1f3a5;系列专栏&#xff1a;力扣刷题总结录 数据结构 云计算 数字图像处理 力扣每日一题_ 【1】100212.统计前后缀下标对 100212. 统计前后缀下标对 Ihttps://leetcode.cn/problems/count-prefix-and-suffix-pairs-i/ 熟…

4.1_4 文件的物理结构

文章目录 4.1_4 文件的物理结构&#xff08;一&#xff09;文件块、磁盘块&#xff08;二&#xff09;文件分配方式——连续分配&#xff08;三&#xff09;文件分配方式——链接分配&#xff08;1&#xff09;链接分配——隐式链接&#xff08;2&#xff09;链接分配——显式链…

OpenStack之存储cinder

一、 存储 1、DAS 1)存储更多的依赖服务器主机操作系统进行数据的IO读写和存储维护管理&#xff0c;数据备份和恢复要求占用服务器主机资源&#xff08;包括CPU、系统IO等&#xff09; 2)直连式存储与服务器主机之间的连接通道通常采用SCSI连接&#xff0c;随着服务器CPU的处…

Type-C接口介绍

1、USB介绍 &#xff08;1&#xff09;标准USB A型连接器&#xff08;左&#xff09;及B型连接器&#xff08;右&#xff09; 引脚1 VCC&#xff08;5V&#xff09; 引脚2 Data- 引脚3 Data 引脚4 接地 &#xff08;2&#xff09;Micro USB 引脚定义及OTG (USB-HOST) …

k8s CKA upgrade - Kubeadm 版本升级实测

升级版本最好是逐步去升级&#xff0c;不要跨越多个大版本&#xff0c;可能会出错 大体流程&#xff1a; 1.先确定升级版本 2.升级kubeadm 3.驱逐节点 4.升级kubelet和kubectl 5.重启kubelet服务 6.恢复节点&#xff0c;使其上线 1.查看现版本&#xff1a;升级版本 kubectl ge…

华为配置Hotspot2.0无线网络示例

配置Hotspot2.0无线网络示例 组网图形 图1 配置Hotspot2.0无线网络组网图 组网需求配置思路配置注意事项操作步骤配置文件 组网需求 某网络服务商在原有移动网络业务的基础上&#xff0c;新增部署WLAN网络接入业务&#xff0c;为用户提供更好的网络体验。但传统的WLAN网络业…

【每日一题】2024年3月汇编(上)

3.1【2369】检查数组是否存在有效划分 2369. 检查数组是否存在有效划分https://leetcode.cn/problems/check-if-there-is-a-valid-partition-for-the-array/ 1.这样的判断可以用动态规划来解决&#xff0c;用一个长度为(n1) 的数组来记录 是否存在有效划分&#xff0c;dp[i]…

Bean的作用域、Bean的自动装配、注解自动装配 (Spring学习笔记五)

1、Bean 的作用域 官网上显示有六种 1、Bean的作用域默认的是singleton&#xff08;单例模式的实现&#xff09; 也可以显示的设置&#xff08;单例模式的实现&#xff09; <!--用scope可以设置Bean的作用域--><bean id"user2" class"com.li.pojo.Us…

NCV8705MTADJTCG稳压器芯片中文资料规格书PDF数据手册引脚图图片价格功能

产品概述&#xff1a; NCV8705 是一款低噪音、低功耗和低泄漏线性电压稳压器。该器件具有卓越的噪音和 PSRR 规格&#xff0c;适用于使用视频接收器、成像传感器、音频处理器或需要外部洁净电源的任何部件的产品。NCV8705 使用创新的自适应接地电流电路 可确保轻负载调节下的超…

http请求方法15种,附图可以下载保存备查。

一、http请求组成和流程 HTTP请求是客户端&#xff08;如浏览器&#xff09;向服务器发送的请求&#xff0c;以获取特定资源或执行特定操作。HTTP请求由以下几个部分组成&#xff1a; 请求行&#xff1a;包含请求方法、请求的URL和HTTP协议版本。常见的请求方法有GET、POST、P…

数据结构的概念大合集01(含数据结构的基本定义,算法及其描述)

概念大合集01 1、数据结构基础的定义2、数据结构2.1 数据元素之间关系的集合2.2数据结构的三要素2.2.1数据的逻辑结构2.2.2数据的存储&#xff08;物理&#xff09;结构2.2.3数据的运算 3、数据类型4、抽象数据类型类型&#xff08;ADT&#xff09;5、算法及其描述5.1算法的5个…

Qt文件以及文件夹相关类(QDir、QFile、QFileInfo)的使用

关于Qt相关文件读写操作以及文件夹的一些知识&#xff0c;之前也写过一些博客&#xff1a; Qt关于路径的处理&#xff08;绝对路径、相对路径、路径拼接、工作目录、运行目录&#xff09;_qt 相对路径-CSDN博客 C/Qt 读写文件_qt c 读取文本文件-CSDN博客 C/Qt读写ini文件_…

Docker学习之数据管理(超详解析)

Docker存储资源类型&#xff1a; 用户在使用 Docker 的过程中&#xff0c;势必需要查看容器内应用产生的数据&#xff0c;或者需要将容器内数据进行备份&#xff0c;甚至多个容器之间进行数据共享&#xff0c;这必然会涉及到容器的数据管理&#xff1a; &#xff08;1&#xff…