组件化开发

一、引言

Vue.js 的组件化开发是其核心特性之一,它允许开发者将复杂的界面拆分为可复用的、独立的、小的组件,从而提高开发效率和代码的可维护性。

二、关键点

        1.组件的定义

在components下创建.vue文件timecard.vue用来编辑内容。

文件创建完毕后,在timecard.vue内编写内容。以演出预告为例,包括演出节目、演出时间、演出状态。

<div class="content"><div>演出节目</div><div>演出时间</div><div>演出状态:</div></div>

然后设置该div的样式

.content {box-shadow: 1px 1px 1px 1px #ccc;width: 300px;height: 50px;margin: 10px;padding: 10px;border-radius: 5px;
}

接着设置index.vue,在index.vue中的div设置标题和timecard的内容。同时在script中引入components文件中的timecard.vue。

 设置完成后打开终端进入locahost查看

 

2.组件的传参:

   1.父传子:

   我们在 timecard内传属性name

        <TimeCard :name="'张三'"></TimeCard>

 然后在timecard中声明一个变量props用definprops来接受这个属性

const props=defineProps({name:String
})
console.log(props);

包含两个值,第一个name表示的是属性名,第二个string表示的是属性类型 

打开html可以看到name已经被传过来了

接着复制一个更改name的值 

 接着我们在index.vue中创建一个存放演出数据的数组,然后在timecard标签中循环这个数组

<template><div class="content"><div>演出节目:{{ props.title }}</div><div>演出时间:{{ props.start }}~{{ props.end }}</div></div>
</template><script setup>
const props = defineProps({title: String,start: String,end: String
})
console.log(props);
</script><style scoped>
.content {box-shadow: 1px 1px 1px 1px #ccc;background-color: #fff;width: 300px;margin: 10px;padding: 10px;border-radius: 5px;
}
</style>

引入计算函数和响应对象

import { computed, ref } from 'vue';

 声明状态的变量名,然后获取当前时分秒

const date = new Date();
let time = `${date.getHours().toString().padStart(2, '0')}:${date.getMinutes().toString().padStart(2, '0')}:${date.getSeconds().toString().padStart(2, '0')}`

之后根据时间来判断演出状态

let status = computed(() => {// 判断演出状态1.未开始 2.进行中 3.已结束if(time<props.start){return{color: '#0000ff',msg: '未开始'};}else{if(time<props.end){return{color: '#00ff00',msg: '进行中'};}else{return {color: '#aaaaaa',msg: '已结束'};}}
})

这样就可以根据首页传来的演出信息来显示演出信息的状态

TimeCard.vue

<template><div class="content" :style="{color: status.color}"><div>演出节目:{{ props.title }}</div><div>演出时间:{{ props.start }}~{{ props.end }}</div><div>演出状态:{{ status.msg }}</div></div>
</template><script setup>
import { computed, ref } from 'vue';
const props = defineProps({title: String,start: String,end: String,status: String
})
const date = new Date();
let time = `${date.getHours().toString().padStart(2, '0')}:${date.getMinutes().toString().padStart(2, '0')}:${date.getSeconds().toString().padStart(2, '0')}`
let status = computed(() => {// 判断演出状态1.未开始 2.进行中 3.已结束if(time<props.start){return{color: '#0000ff',msg: '未开始'};}else{if(time<props.end){return{color: '#00ff00',msg: '进行中'};}else{return {color: '#aaaaaa',msg: '已结束'};}}
})
console.log(props);
</script><style scoped>
.content {box-shadow: 1px 1px 1px 1px #ccc;background-color: #fff;width: 300px;margin: 10px;padding: 10px;border-radius: 5px;
}
</style>

 index.vue

<template><div><h1>index页面</h1><TimeCard v-for="(item, index) in list" :key="index" :title="item.title" :start="item.start" :end="item.end"></TimeCard></div>
</template><script setup>
import TimeCard from '@/components/TimeCard.vue';
let list = [{title: "演出一",start: '08:00:00',end: '09:00:00',status:'未开始'},{title: "演出二",start: '13:00:00',end: '14:00:00',status:'进行中'},{title: "演出三",start: '16:00:00',end: '18:00:00',status:'已结束'}
]</script><style lang="scss" scoped></style>

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

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

相关文章

000_【基础篇】SpringBoot概述

介绍 springboot 是 spring 提供的一个子项目&#xff0c;用于快速构建 spring 应用程序 传统的 SSM 框架要导入很多依赖的 jar 包以及配置很多的配置文件&#xff0c;麻烦、繁琐 springboot 特性 springboot 主要&#xff08;还有其他的一些特性&#xff09;有起步依赖和…

精酿啤酒:开启时尚派对的钥匙

Fendi club啤酒&#xff0c;一个代表着时尚与品味的品牌&#xff0c;如今进入了啤酒市场&#xff0c;推出了名为“Fendi club”的啤酒。这一创新的举措不仅展现了品牌的多元化发展&#xff0c;更为消费者提供了一种全新的时尚生活方式。 Fendi club啤酒不仅仅是一种产品&#x…

【C++庖丁解牛】继承的概念及定义 | 继承中的作用域 | 继承与友元继承与静态成员 | 复杂的菱形继承及菱形虚拟继承

&#x1f341;你好&#xff0c;我是 RO-BERRY &#x1f4d7; 致力于C、C、数据结构、TCP/IP、数据库等等一系列知识 &#x1f384;感谢你的陪伴与支持 &#xff0c;故事既有了开头&#xff0c;就要画上一个完美的句号&#xff0c;让我们一起加油 目录 1.继承的概念及定义1.1继…

【漏洞复现】用友U8Cloud base64 SQL注入漏洞

0x01 产品简介 用友U8 Cloud是用友推出的新一代云ERP&#xff0c;主要聚焦成长型、创新型企业&#xff0c;提供企业级云ERP整体解决方案。 0x02 漏洞概述 用友U8 Cloud 存在SQL注入漏洞&#xff0c;未授权的攻击者可通过此漏洞获取数据库权限&#xff0c;从而盗取用户数据&a…

KVM安装-kvm彻底卸载-docker安装Webvirtmgr

KVM安装和使用 一、安装 检测硬件是否支持KVM需要硬件的支持,使用命令查看硬件是否支持KVM。如果结果中有vmx(Intel)或svm(AMD)字样,就说明CPU的支持的 egrep ‘(vmx|svm)’ /proc/cpuinfo关闭selinux将 /etc/sysconfig/selinux 中的 SELinux=enforcing 修改为 SELinux=d…

AI预测福彩3D第13弹【2024年3月19日预测--第3套算法重新开始计算第2次测试】

今天咱们继续对第3套算法进行第2次测试&#xff0c;第3套算法加入了012路的权重。废话不多说了&#xff0c;直接上结果吧~ 最终&#xff0c;经过研判分析&#xff0c;2024年3月19日福彩3D的七码预测结果如下&#xff1a; 百位&#xff1a;0 1 3 4 2 7 9&#xff08;6换9&#x…

LCR144翻转二叉树(力扣简单题,Java,递归+非递归)

目录 题目描述&#xff1a; 递归代码1&#xff1a; 递归代码2&#xff1a; 非递归代码&#xff08;层次遍历&#xff09;&#xff1a; 题目描述&#xff1a; 给定一棵二叉树的根节点 root&#xff0c;请左右翻转这棵二叉树&#xff0c;并返回其根节点。 示例 1&#xff1a;…

如何在iOS系统抓取log

前言&#xff1a;因为作者目前工作领域和苹果智能家居有关&#xff0c;然后发现一些bug其实是apple sdk原生code的问题&#xff0c;所以需要给apple提radar单&#xff0c;就需要抓ios端Log充当证据给apple看&#xff0c;其实ios抓log非常简单&#xff0c;大家感兴趣可以学习下哦…

VS2022 配置QT5.9.9

QT安装 下载地址&#xff1a;https://download.qt.io/archive/qt/ 下载安装后进行配置 无法运行 rc.exe 下载VS2022 官网下载 配置 1.扩展-管理扩展-下载Qt Visual Studio Tools 安装 2.安装完成后&#xff0c;打开vs2022,点击扩展&#xff0c;会发现多出了QT VS Tools,点…

爱恩斯坦棋小游戏使用C语言+ege/easyx实现

目录 1、游戏介绍和规则 2、需要用到的头文件 3、这里我也配上一个ege和easyx的下载链接吧&#xff0c;应该下一个就可以 4、运行结果部分展示 5、需要用到的图片要放在代码同一文件夹下 6、代码地址&#xff08;里面有需要用到的图片&#xff09; 1、游戏介绍和规则 规则如…

简单介绍注册波兰公司的基本条件

波兰&#xff0c;一个位于中欧的国家&#xff0c;具有丰富的历史文化和资源&#xff0c;同时也拥有稳定的政治和经济环境。在这里&#xff0c;注册公司不仅有助于您拓展业务&#xff0c;还能享受到优惠的税收政策和良好的投资环境。下面&#xff0c;我们将详细介绍注册波兰公司…

Footprint Analytics 强势入局 AI 推出全新投研工具

作者&#xff1a;lesleyfootprint.network 3 月 15 日&#xff0c;链上数据平台 Footprint Analytics 宣布入局 AI&#xff0c;推出了旗下首款 AI 投研工具—— Pea.AI。 作为专门服务于区块链行业的 AI 平台&#xff0c;Pea.AI 旨在提升加密资产投资领域的数据流动性和知识…

镭速,企业传输大文件都在用的udp文件传输工具

在当今快速变化的数字世界中&#xff0c;文件传输工具已成为企业运营不可或缺的一部分。尤其是面对大文件传输的需求&#xff0c;传统的TCP协议由于其设计上的局限性&#xff0c;往往无法满足企业对高速、稳定传输的需求。这时&#xff0c;UDP文件传输工具以其独特的优势走进了…

你知道吗?腾讯云服务器61元一年,2024又降价了

腾讯云服务器多少钱一年&#xff1f;61元一年起。2024年最新腾讯云服务器优惠价格表&#xff0c;腾讯云轻量2核2G3M服务器61元一年、2核2G4M服务器99元一年可买三年、2核4G5M服务器165元一年、3年756元、轻量4核8M12M服务器646元15个月、4核16G10M配置32元1个月、312元一年、8核…

自注意力机制的理解

一、自注意力要解决什么问题 循环神经网络由于信息传递的容量以及梯度消失问题&#xff0c;只能建立短距离依赖关系。为了建立长距离的依赖关系&#xff0c;可以增加网络的层数或者使用全连接网络。但是全连接网络无法处理变长的输入序列&#xff0c;另外&#xff0c;不同的输…

MySQL最实用面试题(2024-3-14持续更新中)

MySQL篇面试题 一、介绍 ​ 这是由小龙同学自己总结领悟的mysql面试题的解析&#xff0c;也是面试宝典 二、题目 1.数据库三大范式&#xff1a; –作用&#xff1a; ​ 使表结构清晰&#xff0c;减少数据冗余&#xff08;简单讲就是重复&#xff09;&#xff0c;提高查询…

朋友圈运营小秘诀,让你事半功倍!

朋友圈已成为了现代社交的重要平台&#xff0c;如何在朋友圈中进行有效的运营&#xff0c;吸引更多的关注和互动&#xff0c;成为了许多人关注的焦点。 今天&#xff0c;我将分享一些朋友圈运营的小秘诀&#xff0c;帮助你事半功倍&#xff0c;让你的朋友圈更具吸引力&#xf…

Qt学习--多态(虚函数)

这次来分享多态的概念&#xff0c;这是比较重要的知识点 面向对象的三大特征&#xff1a;封装、继承、多态 首先&#xff1a;来点官方术语&#xff1a; 多态&#xff0c;通俗来讲就是多种形态&#xff0c;具体点就是去完成某个行为&#xff0c;当不同的对象去完成时会产生出…

【鸿蒙系统】 ---Harmony 鸿蒙编译构建指导(一)

&#x1f48c; 所属专栏&#xff1a;【鸿蒙系统】 &#x1f600; 作  者&#xff1a;我是夜阑的狗&#x1f436; &#x1f680; 个人简介&#xff1a;一个正在努力学技术的CV工程师&#xff0c;专注基础和实战分享 &#xff0c;欢迎咨询&#xff01; &#x1f496; 欢…

实践致知第10享:将微信中的Excel保存到本地并编辑、修改

一、背景需求 小姑打电话问&#xff1a;学校在微信上发来的Excel表格&#xff0c;要求家长填报相关信息&#xff0c;不知道该怎么处理&#xff0c;于是我写了下面的操作步骤。 二、解决方案 1、在电脑上打开微信&#xff0c;选中Excel表格&#xff0c;右键选择“另存为”功能…