版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1项目组件化设计任务5框架技术应用组件是Vue中构成页面各部分的独立结构单元,能实现复杂的页面结构,提高代码的复用性。在实际项目开发中,组件起着非常重要的作用。本任务带领大家认识在Vite环境中组件的注册、引入,以及父子组件之间的传值等技术,建立初步的工程项目化思维。【知识目标】掌握组件的注册和导入;熟练掌握父子组件间的传值技术;掌握插槽的使用步骤。【技能目标】能够掌握利用组件技术拆分复杂页面的能力;能够熟练使用组件间的各项技术。【素质目标】培养精益求精勇于创新的工匠精神;培养高效的团队合作精神。学习目标任务5项目组件化设计项目背景到目前为止,本项目的大部分功能集中在一个App.vue文件中实现,显然是有悖于“高耦合低内聚”的软件设计思想。组件的引入解决了这个问题。组件是构成Vue项目的基本结构单元,能够减少重复代码的编写,提高开发效率,降低代码间的耦合程度,使项目更易维护和管理。不同组件之间具有基本交互功能,能根据业务逻辑实现复杂的项目功能。本项目开发“就业职通车”网站的首页功能,分成几个组件构成,每个组件执行一个功能模块,组件之间可以进行通信,统一由App.vue进行组织管理,提高制作复杂页面的能力。任务规划本任务要求将岗位列表和页面标题进行分别的组件设计,通过使用父子组件间传值技术进行列表内容和点赞数据的传输,使用插槽技术完成标题的统一管理。任务5.1组件设计【任务陈述】本任务学习组件的创建、注册及导入,并对最新岗位列表数据以组件形式重构。【任务分析】该任务的具体实施流程如图5-1所示。图5-1任务实施流程图任务5.1组件设计【任务实施】步骤一.创建子组件Comments.vue。将渲染最新岗位的代码从App.vue中剥离,在src/components目录内新建子组件Comments.vue,提高代码复用性。同时渲染最新岗位所用到的style、function和资源引用路径(img标签),也需要一并剥离。代码如下:<!—Comments.vue子组件--><template> <divclass="d-flextext-mutedmb-3" v-for="(item,index)inmessageList"… …> …<imgsrc="../assets/img/support.png"alt="">//资源路径修改</div></template><scriptsetup>functionparseTime(time){…}</script><stylescoped>.message_sum{}.suppoert{}.supportspan{}.supportActivedimg{}.img{}</style>但此时页面还无法渲染Comments.vue组件,需要在父组件中导入和注册。任务5.1组件设计【任务实施】步骤二.在App.vue中导入注册子组件Comments.vue。<!—App.vue父组件--><scriptsetup>importCommentsfrom"../components/Comments.vue"</script><template><!--最新岗位列表--><divclass="py-5"> <Title>最新岗位</Title><Comments></Comments></div></template>保存后浏览器会报错,原因是子组件的Comments.vue中的messageList数据并未获取。任务5.1组件设计【任务实施】步骤三.通过props父组件向子组件传递数据。在App.vue中利用v-bind绑定来传递动态props值。<!—App.vue父组件--><Commentsv-bind:messageList="messageList.content"v-bind:avatar_male="avatar_male"v-bind:avatar_female="avatar_female"></Comments>在Comment.vue组件中使用defineProps方法在props列表上声明传递的值和类型后,模板中就可以直接使用messageList、avatar_female和avatar_male三个数据。import{toRefs}from'vue'//接收父组件数据和方法constprops=defineProps({ messageList:Array, avatar_female:String, avatar_male:String})//toRefs方法可以将响应式对象的每个属性都转化为ref对象const{messageList,avatar_female,avatar_male}=toRefs(props) 通过以上步骤,父组件数据传递到子组件中,顺利完成数据的渲染。任务5.1组件设计【知识链接】5.1.1组件基础组件(component)是一个具有独立逻辑和功能的界面,不同组件之间又能根据规定的接口规则进行相互通信。每个Web页面的各个功能块,比如头部、导航、弹窗、列表、侧边栏、页脚等都可以看成是一个个的组件,页面只不过是这些组件的容器。组件示意图如图5-2所示。图5-2组件示意图任务5.1组件设计【知识链接】5.1.1组件基础定义组件当使用构建工具时,我们一般会将Vue组件定义在一个单独的
.vue
文件中,也称之为单文件组件
(SingleFileCcomponent,简称SFC),存放在src/components目录内。【例5-1】组件案例。在src/components目录内创建一个计数器组件ButtonCounter.vue,代码如下所示。<template> <button@click="count++">点击了{{count}}次</button></template><scriptsetup> import{ref}from'vue' constcount=ref(0)</script><stylescoped>.red{ color:red;}</style>从以上代码得知,Vue的单文件组件是网页开发中HTML、CSS和JavaScript三种语言经典组合的自然延伸。<template>、<script>
和
<style>
三个块在同一个文件中封装,组合了组件的视图、逻辑和样式。任务5.1组件设计【知识链接】5.1.1组件基础每个组件最多可以包含:一个顶层<template>块;一个<script>块;一个<scriptsetup>(不包括一般的<script>);多个<style>标签。一个
<style>
标签可以使用
scoped
属性来帮助封装当前组件的样式,以免跟其它组件的样式产生冲突。使用组件要使用一个组件,需要在父组件中导入、注册它。注册分为全局注册与局部组件两种方式。任务5.1组件设计【知识链接】5.1.1组件基础全局注册。组件在main.js通过ponent()方法全局注册。通过全局注册的组件在整个当前的Vue应用中都可以使用。格式如下:<!—main.js文件--> import{createApp}from‘vue’importMyComponentfrom‘./App.vue’//1.导入MyComponent组件constapp=createApp({})ponent(//注册的名字’MyComponent’,//2.使用ponent()进行全局注册
//导入的组件MyComponent)//3.在当前整个应用的任意组件模板中通过自定义标签形式使用<template><MyComponet/> //或者使用<my-component></my-component></template>任务5.1组件设计【知识链接】5.1.1组件基础局部注册。局部注册的组件需要在使用它的父组件中显示导入,并且只能在该父组件中使用。格式如下:<scriptsetup>//1.导入ComponentA组件并注册后,模板中可以直接使用importComponentAfrom‘./ComponentA.vue’</script><template>//2.模板中使用自定义标签进行使用,也可以使用<component-a></component-a><ComponentA/></template>任务5.1组件设计【知识链接】5.1.1组件基础组件名的注册格式。在导入和注册时建议使用PascalCase(帕斯卡命名法,即所有单词的首字母大写),在模板使用时可以通过PascalCase或者kebab-case(短横线命名法)。比如,导入和注册使用MyComponent,而在模板使用时<MyComponet/>或<my-component></my-component>。之前已经创建完成的【例5-1】案例计数器组件ButtonCounter.vue,目前在浏览器端无法预览,只有在父组件中注册使用才能查看。代码如下://在App.vue文件中进行导入、注册和使用<scriptsetup>importButtonCounterfrom‘./src/component/ButtonCounter.vue’</script><template><button-counter></button-counter></template>任务5.1组件设计【知识链接】5.1.1组件基础保存后刷新页面即可看到效果,如图5-3所示。图5-3【例5-1】案例组件渲染效果图任务5.1组件设计【知识链接】5.1.2组件之间的数据通信组件的作用域是相互独立的,目的使代码更加简洁,容易维护。但这就意味着不同组件之间的数据无法相互引用。因此需要借助一些工具来实现数据在不同组件间的通信。在Vue中,组件的通信主要通过props和$emit来完成。组件通信示意图如图5-4所示。图5-4组件通信示意图任务5.1组件设计【知识链接】5.1.2组件之间的数据通信props传值父组件把需要传递给子组件的数据,以属性绑定(v-bind)的形式,通过子组件自定义标签传递到子组件内部,供子组件使用。子组件需要在内部定义props属性,接收传递来的数据,才能在子组件中使用。例如,在一个博客项目中,希望所有的博客文章分享相同的视觉布局,但要有不同数据内容。因此需要新建一个显示博客文章的组件,在组件中定义样式和行为,但数据内容来自于父组件,比如每篇文章的标题和内容,这就会使用到props传值技术。【例5-2】props传值案例。代码如下:<!—App.vue父组件--><scriptsetup>importBlogPostfrom‘./components/BlogPost.vue’constposts=ref([{id:1,title:’坚持不懈’},{id:2,title:’努力拼搏’},{id:3,title:’勇于创新’}])</script><template><BlogPostv-for=“postinposts”:key=“post.id”//1.利用v-bind绑定biaoTi来传递props值:biaoTi=“post.title”/></template><!—BlogPost.vue子组件--><scriptsetup>//2.使用defineProps方法在组件上声明props为biaoTidefineProps([‘biaoTi])</script><template><h4>{{biaoTi}}</h4>//3.使用传递过来的props值biaoTi</template>任务5.1组件设计【知识链接】5.1.2组件之间的数据通信props传值效果图如图5-5所示。图5-5【例5-2】props传值案例效果图defineProps是用来设置props的方法,仅能用在<scriptsetup>中,不需要显式导入。声明的props会自动暴露给模板。defineProps返回一个对象,其中包含了可以传递给组件的所有props,传递给defineProps()的参数,除了使用字符串数据来声明props外,还可以使用对象的形式来规定props的值类型,比如,要求一个prop的值是String类型的代码如下:defineProps({biaoTi:String})任务5.1组件设计【知识链接】5.1.2组件之间的数据通信$emit传值$emit能够将子组件中的数据传递到父组件中去。子组件通过$emit触发父组件中定义的事件,子组件数据通过传递参数方式完成。例如,在之前的博客案例【例5-2】中,增加一个功能,将博客文章的文字能够放大,而页面其余部分仍使用默认字号。【例5-2】$emit传值案例,实现代码如下:<!—App.vue父组件--><scriptsetup>constpostFontSize=ref(1)</script><template><div:style=”{fontSize:postFontSize+‘em’}”<BlogPostv-for=“postinposts”:key=“post.id”:biaoTi=“post.title”//1.父组件选择性监听子组件上抛的事件@enlarge-text=“postFontSize+=0.1”/><template><divclass=“blog-post”><h4>{{biaoTi}}</h4><button//3.子组件通过调用内置$emit方法,通过传入事件名来抛出enlarge-text事件,父组件监听到enlarge-text事件,从而更新postFontSize的值。@click=“$emit(‘enlarge-text’)>放大字号</button></div></template>任务5.1组件设计【知识链接】5.1.2组件之间的数据通信</div></template><!—BlogPost.vue子组件--><scriptsetup>//2.通过defineEmits方法定义子组件上抛出的事件defineEmits([‘enlarge-text’])</script><template><divclass=“blog-post”><h4>{{biaoTi}}</h4><button//3.子组件通过调用内置$emit方法,通过传入事件名来抛出enlarge-text事件,父组件监听到enlarge-text事件,从而更新postFontSize的值。@click=“$emit(‘enlarge-text’)>放大字号</button></div></template>任务5.1组件设计【知识链接】5.1.2组件之间的数据通信效果如图5-6所示。图5-6【例5-2】$emit传值案例效果图任务5.1组件设计【知识链接】5.1.2组件之间的数据通信如果需要设置文本放大的具体值,涉及到子组件向父组件传递数据,可以给$emit提供额外的参数,【例5-2】$emit参数传值案例:<!—MyButton子组件--><scriptsetup> defineEmits(['increaseBy'])//1.定义抛出的事件</script><template>//2.触发父组件的increaseBy事件,第2个参数为传递的数据 <button@click="$emit('increaseBy',3)">增大到3</button></template><!—App.vue子组件--><my-button@increaseBy="increaseFontSize"></my-button>//3.父组件接收到的参数n=3,将字号调整到3emfunctionincreaseFontSize(n){ postFontSize.value=n}任务5.1组件设计【知识链接】5.1.2组件之间的数据通信效果如图5-7所示。图5-7【例5-2】$emit参数传值案例效果图任务5.2点赞组件设计【任务陈述】本任务完成子组件Comments.vue中点赞功能。【任务分析】在之前的项目中,我们完成了最新岗位数据的渲染,但点赞功能并未起作用,因为点赞动作发生在子组件Comments.vue中,但渲染的数据却保存在父组件App.vue中。本子任务主要实现通过$emit进行子组件向父组件的通信来实现点赞功能以及点赞图标的切换。同时利用插槽技术完成对岗位标题的动态渲染。图5-8任务实施流程图任务5.2点赞组件设计【任务实施】步骤一.通过$emit传值技术完成点赞功能子组件抛出事件。在组件Comments.vue中声明向父组件抛出的事件parentSupport,并定义点赞事件support<template>
//2.在div上单击时,触发support事件,同时传入当前数据的id值<div:class="['support',{supportActived:item.has_sup}]"v-on:click="support(index)">…</div></template><scriptsetup>//1.定义子组件的抛出事件parentSupportconstemits=defineEmits(['parentSupport'])functionsupport(index){letnewData={data:{id:messageList.value[index].id,email:messageList.value[index].email,name:messageList.value[index].name,
content:messageList.value[index].content,scale:messageList.value[index].scale,
support:messageList.value[index].support+1,has_sup:true,unnamed:messageList.value[index].unnamed,},index:index}//3.触发父组件的parentSupport事件,传入需要修改的数据emits('parentSupport',newData)}</script>任务5.2点赞组件设计【任务实施】步骤一.通过$emit传值技术完成点赞功能父组件接收数据。父组件App.vue接收子组件的数据,修改support方法,完成点赞数据更改。<template><Commentsv-bind:messageList="messageList.content"v-bind:avatar_male="avatar_male"v-bind:avatar_female="avatar_female"//1.父组件监听parentSupport事件,一旦子组件触发则执行父组件的support事件v-on:parentSupport="support"></Comments></template><scriptsetup>//点赞方法functionsupport(newData){
//数据传递给接口postSupportState(newData).then(postResult=>{if(postResult.status==200){getSupportState(newData.data.id).then(getResult=>{if(getResult.status==200){//2.此处数据参数有修改,改为传入数据的index属性messageList.content[newData.index]=getResult.data}})} })}</script>任务5.2点赞组件设计【任务实施】步骤二.利用插槽技术完成标题渲染。将在项目中的“最新岗位”和“岗位发布”的标题设置成组件,并以插槽形式传入数据,方便标题组件的复用。新建子组件Title.vue,设置slot插槽,存放于src/components目录内。<template><h2class="pt-2pb-3title">//标题内容由父组件传入,内容不定,由slot进行占位<span><slot></slot></span></h2></template>父组件App.vue中引入子组件Title,并注册使用。<!--最新岗位列表--><divclass="py-5">//父组件通过组件名标签将“最新岗位”传入子组件Title.vue的插槽处<Title>最新岗位</Title><Comments……></Comments></div>…<tr><tdcolspan="4">//父组件通过组件名标签将“岗位发布”传入子组件Title.vue的插槽处<Title>岗位发布</Title></td></tr>项目保存后,查看效果,顺利渲染。任务5.2点赞组件设计【知识链接】5.2.1插槽组件可以通过接受任意类型的值作为props和$emit进行通信,但组件要如何接收模板内容呢?答案是,需要通过插槽体来实现。Vue为了实现组件的内容分发,提供了一套用于组件内容分发的API,也就是插槽。工作示意图如图5-9所示。图5-9插槽工作示意图【例5-3】插槽案例。以下代码实现子组件的按钮文字由父组件传入。<!—父组件--><template><child-button>发送</child-button> <child-button>重置</child-button> <child-button>帮助</child-button></template><!—子组件--><template><button><slot></slot></button></template>任务5.2点赞组件设计【知识链接】5.2.1插槽效果如图5-10所示。图5-10【例5-3】插槽案例实现效果图插槽分为默认内容、具名插槽、作用域插槽、动态插槽、具名作用域插槽。本教材介绍前3个插槽。任务5.2点赞组件设计【知识链接】5.2.2默认内容插槽在父组件没有提供任何内容的情况下,可以为插槽指定默认内容,只需将默认内容写在标签中间。【例5-4】默认内容插槽案例。代码如下:<child-button></child-button>//父组件<button>//子组件<slot>Submit</slot></button>//按钮上的文字渲染为Submit但是如果提供了插槽内容,并且同时也有默认内容,则被显式提供的内容会取代默认内容,【例5-4】改写代码如下:<child-button>发送</child-button>//父组件<button>//子组件<slot>Submit</slot></button>//按钮上的文字渲染为发送任务5.2点赞组件设计【知识链接】5.2.3具名插槽在实际开发中,组件中的插槽不止一个,有时需要多个插槽,这时需要给插槽通过name属性来命名,用来给各个插槽分配唯一的ID,以确定每一处要渲染的内容,这类带name的插槽被称之为具名插槽,没有提供name的插槽出口会带有隐含的”default”。【例5-5】具名插槽案例,子组件代码如下:<div><header><slotname=’header’><slot></header><main><slot><slot></main><footer><slotname=’footer’><slot></footer></div> 在为具名插槽提供内容时,需要使用一个含v-slot指令的template元素,并将目标插槽的名字传给该指令。任务5.2点赞组件设计【知识链接】5.2.3具名插槽同时v-slot有对应的简写#,【例5-5】具名插槽案例,父组件代码如下:<child-layout><templatev-slot:header>这是头部内容 </template> <template#footer>//相当于<templatev-slot:footer>这是页脚内容<template>//相当于<templatev-slot:default><p>…</p></template><p>这是页面主体内容</p></child-layou
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 个人抵押贷款协议模板版
- 专业借款中介服务协议2024版B版
- 月度团队总结模板
- 2025年度茶叶品牌加盟连锁经营协议范本4篇
- 个人吊车租赁协议
- 二零二五年度跨境电商进口贸易合同样本3篇
- 2025年度智能家居系统定制销售合同4篇
- 2025年度智能交通管理系统全国代理合同4篇
- 二零二五年度存单质押养老产业金融服务合同3篇
- 2024版移动通信网络建设与维护合同
- 农民工工资表格
- 【寒假预习】专题04 阅读理解 20篇 集训-2025年人教版(PEP)六年级英语下册寒假提前学(含答案)
- 2024年突发事件新闻发布与舆论引导合同
- 地方政府信访人员稳控实施方案
- 小红书推广合同范例
- 商业咨询报告范文模板
- 2024年智能监狱安防监控工程合同3篇
- 幼儿园篮球课培训
- AQ 6111-2023个体防护装备安全管理规范知识培训
- 老干工作业务培训
- 基底节脑出血护理查房
评论
0/150
提交评论