新闻中心
为动态生成的HTML表格实现星级评分

本文档旨在解决在动态生成的HTML表格中实现星级评分功能时,遇到的评分错乱问题。通过修改J*aScript代码,确保每个表格行的星级评分独立工作,互不影响。文章将提供详细的代码示例和解释,帮助开发者轻松实现此功能。
在动态生成的HTML表格中添加星级评分功能时,一个常见的问题是多个评分组件之间相互干扰,导致修改一个评分会影响到其他评分。这通常是由于在生成HTML时,多个评分组件使用了相同的id和name属性。本文将介绍如何通过修改J*aScript代码,为每个评分组件生成唯一的id和name,从而解决这个问题。
问题分析
问题的根源在于HTML元素的id和name属性的重复使用。在HTML中,id属性应该在整个文档中是唯一的。当多个元素具有相同的id时,J*aScript代码可能会错误地选择到错误的元素。类似地,当多个radio按钮具有相同的name属性时,浏览器会将它们视为同一组,导致只能选择其中一个。
解决方案
为了解决这个问题,我们需要为每个评分组件生成唯一的id和name属性。一种简单的方法是将事件名称添加到id和name属性中。这样,每个评分组件的id和name属性都将是唯一的。
以下是修改后的J*aScript代码:
通用产品企业网站(.NET2.0)1.0
1、系统采用.net2.0开发,数据库access2、三层架构,数据层、逻辑层和表示层分离3、系统完全使用div+css布局,可以灵活处理界面4、技术特点: 使用模板页,大大减少代码量 动态生成竖向导航菜单 ul li实现表格 各种自定义用户空间 Reapter等数据控件的灵活运用
0
查看详情
$(document).ready(function () {
function addData() {
var eventname = $("#eventname").val();
var eventdate = $("#eventdate").val();
var eventloc = $("#eventloc").val();
var eventauthor = $("#eventauthor").val();
var eventdesc = $("#eventdesc").val();
if (eventname.trim() === '' || eventdate.trim() === '' || eventloc.trim() === '' || eventauthor.trim() === '' || eventdesc.trim() === '') {
alert("Bitte fllen Sie alle Felder aus");
return;
}
if (!isValidDate(eventdate)) {
alert("Datum muss folgendem Format entsprechen: dd.mm.yyyy ein");
return;
}
// Validierung und Hinzufgen zur Tabelle
$(".table tbody tr").last().after(
'<tr>' +
'<td><input type="checkbox" id="select-row"></td>' +
'<td>' + eventname + '</td>' +
'<td>' + eventdate + '</td>' +
'<td>' + eventloc + '</td>' +
'<td>' + eventdesc + '</td>' +
'<td>' + eventauthor + '</td>' +
'<td><button class="btn btn-link like-button">Gefällt mir</button></td>' +
'<td><div class="rate"><input type="radio" id="'+eventname+'5" name="'+eventname+'rate" value="5" /><label for="'+eventname+'5" title="text">5 stars</label><input type="radio" id="'+eventname+'4" name="'+eventname+'rate" value="4" /><label for="'+eventname+'4" title="text">4 stars</label><input type="radio" id="'+eventname+'3" name="'+eventname+'rate" value="3" /><label for="'+eventname+'3" title="text">3 stars</label><input type="radio" id="'+eventname+'2" name="'+eventname+'rate" value="2" /><label for="'+eventname+'2" title="text">2 stars</label><input type="radio" id="'+eventname+'1" name="'+eventname+'rate" value="1" /><label for="'+eventname+'1" title="text">1 star</label></div></td>'
+ '</tr>'
);
function isValidDate(dateString) {
var regex = /^\d{2}\.\d{2}\.\d{4}$/;
return regex.test(dateString);
}
}
// Eventlistener fr den Button
$('#addData').click(addData);
$('.table').on('click', '.like-button', function () {
$(this).toggleClass('liked');
if ($(this).hasClass('liked')) {
$(this).text('Gefällt mir nichtmehr');
$(this).closest('tr').addClass('liked-event');
} else {
$(this).text('Gefällt mir');
$(this).closest('tr').removeClass('liked-event');
}
});
});在上面的代码中,我们将每个radio按钮的id属性修改为eventname + 5、eventname + 4等等,并将name属性修改为eventname + rate。这样,每个评分组件的id和name属性都将是唯一的。
完整示例代码
以下是完整的HTML、CSS和J*aScript代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>Eventüberblick</title>
<link href="style.css" rel="stylesheet" type="text/css">
<!-- Bootstrap 4 CDN -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.16.0/umd/popper.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js"></script>
<script src="Script1.js"></script>
<!-- Fontawesome CDN Link -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.2.1/css/all.min.css" />
</head>
<header>
<a href="index.html">Überblick</a>
<a href="CreateEvent.html">Event erstellen</a>
</header>
<body>
<h1 class="headline" style="text-align: center;">Neues Event</h1>
<div class="container">
<div class="form-div">
<div class="row">
<div class="col-md-3">
<input type = "text" class="form-control" id="eventname" placeholder="Eventname">
</div>
<div class="col-md-3">
<input type = "datetime" class="form-control" id="eventdate" placeholder="Eventdatum">
</div>
<div class="col-md-3">
<input type = "text" class="form-control" id="eventloc" placeholder="Eventort">
</div>
<div class="col-md-3">
<input type = "text" class="form-control" id="eventauthor" placeholder="Eventautor">
</div>
<div class="col-md-3">
<input type = "text" class="form-control" id="eventdesc" placeholder="Eventbeschreibung">
</div>
<div class="col-md-3" style="text-align: right;">
<button class="btn btn-primary" id="addData">Hinzufügen</button>
</div>
</div>
</div>
<h2 class="headline" style="text-align: center;">Eventliste</h2>
<div class="container">
<table class="table">
<thead>
<tr>
<th>All<input type="checkbox" id="select-all"></th>
<th>Eventname</th>
<th>Eventdatum</th>
<th>Eventort</th>
<th>Eventbeschreibung</th>
<th>Eventautor</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
</tr>
</tbody>
</table>
</div>
</div>
<script></script>
</body>
</html>*{
margin: 0;
padding: 0;
}
.rate {
float: left;
height: 46px;
padding: 0 10px;
}
.rate:not(:checked) > input {
position:absolute;
top:-9999px;
}
.rate:not(:checked) > label {
float:right;
width:1em;
overflow:hidden;
white-space:nowrap;
cursor:pointer;
font-size:30px;
color:#ccc;
}
.rate:not(:checked) > label:before {
content: '★ ';
}
.rate > input:checked ~ label {
color: #ffc700;
}
.rate:not(:checked) > label:hover,
.rate:not(:checked) > label:hover ~ label {
color: #deb217;
}
.rate > input:checked + label:hover,
.rate > input:checked + label:hover ~ label,
.rate > input:checked ~ label:hover,
.rate > input:checked ~ label:hover ~ label,
.rate > label:hover ~ input:checked ~ label {
color: #c59b08;
}$(document).ready(function () {
function addData() {
var eventname = $("#eventname").val();
var eventdate = $("#eventdate").val();
var eventloc = $("#eventloc").val();
var eventauthor = $("#eventauthor").val();
var eventdesc = $("#eventdesc").val();
if (eventname.trim() === '' || eventdate.trim() === '' || eventloc.trim() === '' || eventauthor.trim() === '' || eventdesc.trim() === '') {
alert("Bitte fllen Sie alle Felder aus");
return;
}
if (!isValidDate(eventdate)) {
alert("Datum muss folgendem Format entsprechen: dd.mm.yyyy ein");
return;
}
// Validierung und Hinzufgen zur Tabelle
$(".table tbody tr").last().after(
'<tr>' +
'<td><input type="checkbox" id="select-row"></td>' +
'<td>' + eventname + '</td>' +
'<td>' + eventdate + '</td>' +
'<td>' + eventloc + '</td>' +
'<td>' + eventdesc + '</td>' +
'<td>' + eventauthor + '</td>' +
'<td><button class="btn btn-link like-button">Gefällt mir</button></td>' +
'<td><div class="rate"><input type="radio" id="'+eventname+'5" name="'+eventname+'rate" value="5" /><label for="'+eventname+'5" title="text">5 stars</label><input type="radio" id="'+eventname+'4" name="'+eventname+'rate" value="4" /><label for="'+eventname+'4" title="text">4 stars</label><input type="radio" id="'+eventname+'3" name="'+eventname+'rate" value="3" /><label for="'+eventname+'3" title="text">3 stars</label><input type="radio" id="'+eventname+'2" name="'+eventname+'rate" value="2" /><label for="'+eventname+'2" title="text">2 stars</label><input type="radio" id="'+eventname+'1" name="'+eventname+'rate" value="1" /><label for="'+eventname+'1" title="text">1 star</label></div></td>'
+ '</tr>'
);
function isValidDate(dateString) {
var regex = /^\d{2}\.\d{2}\.\d{4}$/;
return regex.test(dateString);
}
}
// Eventlistener fr den Button
$('#addData').click(addData);
$('.table').on('click', '.like-button', function () {
$(this).toggleClass('liked');
if ($(this).hasClass('liked')) {
$(this).text('Gefällt mir nichtmehr');
$(this).closest('tr').addClass('liked-event');
} else {
$(this).text('Gefällt mir');
$(this).closest('tr').removeClass('liked-event');
}
});
});将上述代码保存为HTML、CSS和J*aScript文件,并在浏览器中打开HTML文件。您将能够动态地向表格中添加事件,并为每个事件独立地进行星级评分。
总结
通过为每个评分组件生成唯一的id和name属性,我们可以解决在动态生成的HTML表格中实现星级评分功能时遇到的评分错乱问题。这种方法简单有效,可以确保每个评分组件独立工作,互不影响。在实际开发中,可以根据具体情况选择合适的方法来生成唯一的id和name属性。例如,可以使用时间戳、随机数或者其他唯一标识符。
以上就是为动态生成的HTML表格实现星级评分的详细内容,更多请关注其它相关文章!
# 都将
# 杭州营销推广路径图
# 淘宝营销推广教程视频
# 网站推广的公司认可t火17星热情
# 福建seo合作
# 杭州视频营销推广公司
# 苏州seo优化物流
# 南通管理网站建设介绍
# 深圳网站建设yuntianxia
# seo站群管理软件
# 兰州如何做seo优化
# 文档
# 容器内
# 拖拽
# 是唯一
# 解决这个问题
# css
# 自定义
# 复选框
# 企业网站
# 多个
# ai
# 浏览器
# go
# ajax
# bootstrap
# js
# html
# jquery
# java
# javascript
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
大象笔记网页版入口 印象笔记网页版登录入口
如何创建没有密码的Windows本地账户_跳过微软账户登录的技巧【教程】
拷贝漫画电脑版官网入口 拷贝漫画(PC版)在线直达
抖音极速版最新版本 抖音极速版官方下载地址
可靠CSGO开箱平台解析 CSGO开箱网合集
淘宝支付提示失败如何解决 淘宝支付流程优化方法
《噬血代码2》新预告片发布 展示游戏剧情
顺丰快递查询系统 官方正版查询入口
Python:递归比较文件夹内容并找出特定类型文件的差异
谷歌google账号怎么注册账号 谷歌账号注册官方流程
内存疯狂猛猛涨价:主板销量直接腰斩!
Linux如何构建多环境配置管理_Linux多环境配置方案
outlook中文官网入口地址 outlook官方中文版直达首页链接
Golang指针如何与map组合使用_Golang map指针组合实践
2026春节假期时间安排 2026春节假日查询
解决Flask中Quill编辑器内容提交失败及TypeError的指南
京东京造J1和网易云音乐氧气真无线有什么不同_国产电商蓝牙耳机音质对比
汽水音乐车机版8.9下载 汽水音乐车机版8.9版本安装入口
b站怎么删除评论_b站评论管理与删除操作
在J*a中如何在J*a中使用异常机制记录错误日志_异常日志实践经验
Golang如何实现容器化日志收集与分析_Golang容器日志收集分析方法
J*a里如何使用N*igableMap进行导航操作_可导航Map操作技巧解析
支付宝如何设置安全保护_支付宝安全设置的全面教程
曝R星经典之作开发图 设计简陋但信息密集!
构建轻量级网站内部消息系统:Formspree 集成指南
CKEditor 5 自定义构建在React应用中渲染失败的调试与解决
Go RPC HTTP服务正确实现与常见陷阱解析
Win11 USB传输速度慢怎么解决 Win11 USB驱动更新与设置
J*aScript对象创建方式_J*aScript设计模式应用
Python模块化编程:有效管理依赖与避免循环引用
Win11蓝牙耳机断连怎么解决 Win11蓝牙设置重新配对与驱动更新【技巧】
如何使用Node.js csv 包按条件移除含空字段的CSV记录
12306怎么选座位选到安静区_12306选座安静区域选择策略
抖音隐秘迷城小游戏入口_ 抖音冒险解谜小游戏秒玩
Composer的 "conflict" 字段有什么用_如何声明不兼容的包以避免依赖冲突
在Blazor WebAssembly应用中动态注入客户端特定指标代码的策略
钉钉视频会议声音异常如何处理 钉钉会议音频修复技巧
蛙漫漫画官网在线入口 蛙漫全本漫画免费阅读平台
C++如何实现异步操作_C++11使用std::future和std::async进行异步编程
铁路12306官网网页端快速入口 铁路12306官方首页登录教程
苹果手机如何防止被恶意App追踪
快手官方唯一登录入口 谨防山寨钓鱼网站
Kafka Streams中基于消息头条件过滤消息的实现指南
MAC怎么让Dock栏只显示当前运行的应用_MAC终端命令实现极简Dock栏
文心一言怎样用插件调度API数据_文心一言用插件调度API数据【API调用】
Composer中的^和~符号代表什么_精通Composer版本号语义化约束
mysql如何设置表访问权限_mysql表访问权限配置
迅雷下载到U盘速度很慢怎么办_迅雷U盘下载慢优化方法
J*aScript中高效管理与清空动态列表:避免循环陷阱
Word2013如何插入视频和音频媒体_Word2013媒体插入的多媒体支持


2025-10-22
浏览次数:次
返回列表
'<td>' + eventloc + '</td>' +
'<td>' + eventdesc + '</td>' +
'<td>' + eventauthor + '</td>' +
'<td><button class="btn btn-link like-button">Gefällt mir</button></td>' +
'<td><div class="rate"><input type="radio" id="'+eventname+'5" name="'+eventname+'rate" value="5" /><label for="'+eventname+'5" title="text">5 stars</label><input type="radio" id="'+eventname+'4" name="'+eventname+'rate" value="4" /><label for="'+eventname+'4" title="text">4 stars</label><input type="radio" id="'+eventname+'3" name="'+eventname+'rate" value="3" /><label for="'+eventname+'3" title="text">3 stars</label><input type="radio" id="'+eventname+'2" name="'+eventname+'rate" value="2" /><label for="'+eventname+'2" title="text">2 stars</label><input type="radio" id="'+eventname+'1" name="'+eventname+'rate" value="1" /><label for="'+eventname+'1" title="text">1 star</label></div></td>'
+ '</tr>'
);
function isValidDate(dateString) {
var regex = /^\d{2}\.\d{2}\.\d{4}$/;
return regex.test(dateString);
}
}
// Eventlistener fr den Button
$('#addData').click(addData);
$('.table').on('click', '.like-button', function () {
$(this).toggleClass('liked');
if ($(this).hasClass('liked')) {
$(this).text('Gefällt mir nichtmehr');
$(this).closest('tr').addClass('liked-event');
} else {
$(this).text('Gefällt mir');
$(this).closest('tr').removeClass('liked-event');
}
});
});