elementui组件库实现电影选座面板demo

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

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Cinema Seat Selection</title><!-- 引入Element UI的CSS --><link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css"><!-- 引入Vue --><script src="https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.js"></script><!-- 引入Element UI的JavaScript --><script src="https://unpkg.com/element-ui/lib/index.js"></script><style>.seat-selection {max-width: 600px;margin: 50px auto;}.seat-row {display: flex;justify-content: space-around;margin-bottom: 10px;}.seat {width: 50px;height: 50px;line-height: 50px;text-align: center;border: 1px solid #ddd;cursor: pointer;border-radius: 5px;display: flex;align-items: center;justify-content: center;}.seat.selected {background-color: #409EFF;color: white;}.seat.unavailable {background-color: #F56C6C;color: white;cursor: not-allowed;}.modal-content {max-width: 600px;margin: 20px auto;padding: 20px;background-color: #f0f0f0;border: 1px solid #ccc;border-radius: 5px;}.modal-footer {text-align: right;margin-top: 20px;}</style>
</head>
<body>
<div id="app"><el-button type="primary" @click="openAdminModal">设置损坏座位</el-button><!-- 管理员模态框开始 --><el-dialogtitle="设置损坏座位":visible.sync="adminModalVisible"width="60%":before-close="handleAdminModalClose"><div class="modal-content"><p>点击座位来设置损坏状态:</p><div v-for="row in seats" :key="row.rowNumber" class="seat-row"><divv-for="seat in row.seats":key="seat.number"class="seat":class="{ selected: seat.damaged }"@click="toggleDamagedSeat(seat)">{{ seat.number }}</div></div></div><div class="modal-footer"><el-button type="primary" @click="saveDamagedSeats">保存设置</el-button></div></el-dialog><!-- 管理员模态框结束 --><div class="seat-selection"><div v-for="row in seats" :key="row.rowNumber" class="seat-row"><divv-for="seat in row.seats":key="seat.number"class="seat":class="{ selected: seat.selected, unavailable: seat.unavailable || seat.damaged }"@click="selectSeat(row.rowNumber, seat.number)"><i class="el-icon-milk-tea"></i>{{ seat.number }}</div></div><el-button type="primary" @click="confirmSelection">确认选座</el-button></div><div v-if="selectedSeats.length > 0" class="selected-seats"><h3>你选中的座位:</h3><ul><li v-for="seat in selectedSeats" :key="seat">{{ seat }}</li></ul></div>
</div><script>new Vue({el: '#app',data() {return {seats: [{ rowNumber: 1, seats: [] },{ rowNumber: 2, seats: [] },{ rowNumber: 3, seats: [] }],selectedSeats: [],adminModalVisible: false,adminDamagedSeats: [] // 管理员设置的损坏座位};},mounted() {// 初始化座位数据this.initSeats();},methods: {initSeats() {// 初始化座位信息,包括座位号和是否损坏状态const seatCount = 3; // 每行座位数量for (let i = 0; i < this.seats.length; i++) {for (let j = 0; j < seatCount; j++) {this.seats[i].seats.push({number: j + 1,selected: false,unavailable: false,damaged: false});}}},openAdminModal() {// 打开管理员模态框时初始化损坏座位状态this.adminModalVisible = true;},toggleDamagedSeat(seat) {// 切换座位的损坏状态seat.damaged = !seat.damaged;},saveDamagedSeats() {// 保存管理员设置的损坏座位this.adminDamagedSeats = [];this.seats.forEach(row => {row.seats.forEach(seat => {if (seat.damaged) {this.adminDamagedSeats.push(seat.number);}});});this.adminModalVisible = false;},selectSeat(rowNumber, seatNumber) {const row = this.seats.find(r => r.rowNumber === rowNumber);const seat = row.seats.find(s => s.number === seatNumber);if (!seat.unavailable && !seat.damaged) {seat.selected = !seat.selected;}},confirmSelection() {this.selectedSeats = [];this.seats.forEach(row => {row.seats.forEach(seat => {if (seat.selected) {this.selectedSeats.push(`Row ${row.rowNumber} Seat ${seat.number}`);}});});if (this.selectedSeats.length === 0) {this.$message({message: '你还没有选中任何座位',type: 'warning'});} else {this.$message({message: '选座成功!',type: 'success'});}},handleAdminModalClose(done) {// 处理管理员模态框关闭时的逻辑done();}}});
</script>
</body>
</html>

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

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

相关文章

华为、H3C交换机常用巡检命令

一、硬件状态、IOS版本信息检查 • display clock&#xff1a;显示系统时间。 • display version&#xff1a;查看交换机的版本信息和最近一次重新启动的时间。 • display enviroment&#xff1a;显示设备温度。 • display device&#xff1a;显示单板运行状态。 • di…

论文伪代码Latex参考

模版1 \documentclass{article} \usepackage{algorithm} \usepackage{algpseudocode}\begin{document}\begin{algorithm} \caption{AST Pruning Algorithm} \begin{algorithmic}[1]\State $F_k \gets \text{false}$, $F_f \gets \text{false}$, $T \gets R$ \Comment{Initial …

前端中的深拷贝

第1部分&#xff1a;引言 深拷贝&#xff1a;前端开发的隐形守护者 在前端开发的世界里&#xff0c;数据的传递和状态的管理是构建用户界面的基础。然而&#xff0c;数据的复制常常被忽视&#xff0c;直到它引发bug&#xff0c;我们才意识到它的重要性。深拷贝&#xff0c;这…

122.网络游戏逆向分析与漏洞攻防-邮件系统数据分析-邮件物品箱的管理

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 如果看不懂、不知道现在做的什么&#xff0c;那就跟着做完看效果&#xff0c;代码看不懂是正常的&#xff0c;只要会抄就行&#xff0c;抄着抄着就能懂了 内容…

【论文精读】ViM: Out-Of-Distribution with Virtual-logit Matching 使用虚拟分对数匹配的分布外检测

文章目录 一、文章概览&#xff08;一&#xff09;问题来源&#xff08;二&#xff09;文章的主要工作&#xff08;三&#xff09;相关研究 二、动机&#xff1a;Logits 中缺失的信息&#xff08;一&#xff09;logits&#xff08;三&#xff09;基于零空间的 OOD 评分&#xf…

你还在手动操作仓库?这款 CLI 工具让你效率飙升300%!

前言 作为一名开发者&#xff0c;我经常会在 GitHub 和 Gitee 上 fork 各种项目。时间一长&#xff0c;这些仓库就会堆积如山&#xff0c;变成了“垃圾仓库”。每次打开代码托管平台&#xff0c;看到那些不再需要的仓库&#xff0c;我的强迫症就会发作。手动一个一个删除这些仓…

统计学三学习笔记

一&#xff0c;t分布 二&#xff0c;置信区间 最终要用② n越大&#xff0c;s越小&#xff0c;置信区间越小 三&#xff0c;配对样本t检验 假如有两个族群&#xff1a;

Android 2ndBLE的实现

没有需求创造需求 有没有想过一件事情&#xff0c;假如你的手机关机了&#xff0c;而且在家里怎么都找不到的情况&#xff1f; 那么通过另外一种手机进行查找是不是可以&#xff1f;听上去有点搞笑&#xff0c;但实际上确实有这样的需求存在。实现方案是用超低功耗蓝牙&#…

一文弄懂window

iframeDoc.write(<div> printContent </div>);setTimeout(function(){iframe.contentWindow.print();document.body.removeChild(iframe);}, 50);} </script>## 三、强行插入分页当需要自定义打印分页时机时&#xff0c;可通过如下方式将指定 DOM 设为分割…

【Godot4自学手册】第四十二节实现拖拽进行物品交换和数量叠加

这一节我们主要学习背包系统中的物品拖拽后&#xff0c;物品放到新的位置&#xff0c;或交换物品位置&#xff0c;如果两个物品属于同一物品则数量相加。具体效果如下&#xff1a; 一、修改item.tscn场景 给item.tscn场景的根节点Item添加Label子节点&#xff0c;命名为Numv…

vue3基于axios配置请求拦截器响应拦截器以及无感刷新token的实现

vue3基于axios配置请求拦截器响应拦截器以及无感刷新token的实现 一、下载并引入 axios二、引入 element-plus 消息提示三、配置基础地址四、创建 axios 实例五、配置请求拦截器六、定义是否刷新 token 的变量以及存储请求队列的数组七、配置响应拦截器以及实现无感刷新 token八…

Linux CentoS安装RabbitMQ:一键安装指南

有两种安装方法&#xff0c;官方推荐使用 docker安装RabbitMQ 一、Docker安装RabbitMQ 1、安装docker 参考我之前的文章&#xff1a;Centos7.5搭建docker并且部署Lnmp环境&#xff08;小白入门docoker&#xff09;_centos7.5安装docker和docker-compose-CSDN博客 2、安装Ra…

【实用软件】Paragon NTFS for Mac 15下载及安装教程

​习惯上来说所有操作只需轻轻一点&#xff1a;轻量级的快捷菜单栏&#xff0c;可访问所有NTFS驱动器并执行最常见的卷操作&#xff0c;如挂载&#xff0c;卸载和验证&#xff0c;从菜单栏中快速启动NTFS for Mac界面&#xff0c;一键点击&#xff0c;更加方便。11510182322410…

Scope XY Project的使用

1.Scope XY Project的功能介绍与使用方法 添加监控变量 绘制成一个三角形 XY进行对调操作 修改XY轴的比例修改显示输出 2.Cursor的使用方法 游标线的添加测量 3.Reporting功能的使用方法 到处对应的报表数据 添加对应的报告数据

一、Jquery入门(超详)

* [5.3 jQuery 对象和 DOM 对象之间的相互转换](about:blank#53_jQuery__DOM__271)* * [5.3.1 jQuery 对象转换为 DOM 对象](about:blank#531_jQuery__DOM__282)* [5.3.2 DOM 对象转换为 jQuery 对象](about:blank#532_DOM__jQuery__295)六、 解决 jQuery 和其他库的冲…

vue3 中v-model语法糖(2024-06-21)

一、 vue2 中 v-model 语法糖 实现父子组件双向数据绑定&#xff0c;一个输入框或者组件指定绑定一个 v-model 1. 父组件写法 <template><div><h1>App</h1><h2>{{ count }}</h2><input type"text" v-model"count&quo…

Apache Calcite - 使用框架Sql解析器解析Sql

前言 Calcite提供了org.apache.calcite.sql.parser.SqlParser来解析sql&#xff0c;通过访问者模式&#xff0c;在解析过程中访问Sql中的不同元素&#xff0c;最终完成特定的功能。 使用举例 使用Calcite解析SQL主要涉及以下几个步骤&#xff1a; 创建SqlParser对象&#xf…

Linux:基础IO(三.软硬链接、动态库和静态库、动精态库的制作和加载)

上次介绍了基础IO&#xff08;二&#xff09;&#xff1a;Linux&#xff1a;基础IO&#xff08;二.缓冲区、模拟一下缓冲区、详细讲解文件系统&#xff09; 文章目录 1.软硬链接1.1硬链接1.2软链接使用场景 2.动态库和静态库1.1回顾1.2静态库的制作和使用为什么要有库制作者角度…

重学java 85.Java反射、注解、枚举总结

凡事往好处想&#xff0c;人生便会豁达 —— 24.6.24 一、Junit单元测试 1.概述: Junit是一个单元测试框架,可以代替main方法去执行其他的方法 2.使用 a.导入jar包 b.注解 Test —— 单独执行一个方法 Before —— 在Test之前执行.有多少个Test执行.Before对应的方法就执行多少…

常见排序算法及其C语言实现

排序算法在计算机科学中是一个非常重要的主题。本文将详细介绍几种常见的排序算法&#xff0c;包括快速排序、归并排序、堆排序、冒泡排序、选择排序、插入排序、桶排序和二分查找插入排序&#xff0c;并提供每种算法的C语言实现代码。 1. 快速排序&#xff08;Quick Sort&…