新闻中心

为动态生成的HTML表格实现星级评分功能

2025-10-22
浏览次数:
返回列表

为动态生成的html表格实现星级评分功能

本文档旨在解决在动态生成的HTML表格中实现星级评分功能时遇到的问题。通过用户输入动态生成表格,并为每一行添加星级评分功能。文章将详细介绍如何修改现有的HTML、CSS和J*aScript代码,以确保每个表格行都能独立进行评分,避免评分错乱的问题。主要通过修改radio按钮的id和name属性,使其与对应的事件名称关联,从而实现每个事件的独立评分。

在构建动态Web应用时,经常需要根据用户输入动态生成HTML元素,例如表格。如果需要在这些动态生成的元素中添加交互功能,例如星级评分,就需要特别注意元素的ID和Name属性,以避免冲突和功能错乱。本教程将以一个动态生成HTML表格并为其添加星级评分功能的例子,详细讲解如何解决评分错乱的问题。

问题描述

假设你正在构建一个网站,该网站能够动态地将用户输入的事件存储在一个HTML表格中。每个存储的事件都可以通过一个星级评分系统进行评分。你已经使用HTML、J*aScript和CSS实现了一个星级评分系统,但是当前系统只允许对一个元素进行评分。如果在列表中有两个元素,尝试对第二个元素进行评分时,第一个元素的值会被改变,而第二个元素的值无法改变。

原因分析

出现这个问题的主要原因是,在动态生成的表格中,每个事件的星级评分radio按钮都使用了相同的id和name属性。这导致浏览器无法区分用户点击的是哪个事件的评分radio按钮,从而导致评分错乱。

具体来说,HTML代码中,星级评分的radio按钮如下所示:

<div class="rate">
    <input type="radio" id="star5" name="rate" value="5" /><label for="star5" title="text">5 stars</label>
    <input type="radio" id="star4" name="rate" value="4" /><label for="star4" title="text">4 stars</label>
    <input type="radio" id="star3" name="rate" value="3" /><label for="star3" title="text">3 stars</label>
    <input type="radio" id="star2" name="rate" value="2" /><label for="star2" title="text">2 stars</label>
    <input type="radio" id="star1" name="rate" value="1" /><label for="star1" title="text">1 star</label>
</div>

可以看到,所有的radio按钮都使用了相同的id(如star5, star4等)和name(rate)。当用户点击其中一个radio按钮时,浏览器会选择所有具有相同name属性的radio按钮,并将其中的一个设置为选中状态。由于所有事件的radio按钮都具有相同的name,因此点击一个事件的radio按钮会影响到所有事件的评分。

野羊分类信息系统 野羊分类信息系统

===更新说明==解决了无法登陆后台的问题!完善了部分功能修复了一个BUG..修改静态模版说明:本系统的首页 和 内容页 不支持动态显示,需要生成HTML(实为.asp文件)模版文件存放在temp目录下index.html为首页模版show.html为内容页模版......=============2007 - 10 - 20 ===========注:1*使用前请务必修改 inc/conn.as

野羊分类信息系统 0 查看详情 野羊分类信息系统

解决方案

为了解决这个问题,需要确保每个事件的星级评分radio按钮都具有唯一的id和name属性。一种简单的做法是将事件名称添加到id和name属性中。

具体来说,在J*aScript代码中,修改动态生成表格行的代码,将id和name属性修改为:

$(".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&quot; 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>'
);

在这个修改后的代码中,id属性被修改为'"+eventname+"5', '"+eventname+"4'等,name属性被修改为'"+eventname+"rate'。这样,每个事件的星级评分radio按钮都具有唯一的id和name属性,从而避免了评分错乱的问题。

完整代码

下面是完整的修改后的代码:

$(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');
        }
    });
});

注意事项

  • 确保事件名称是唯一的,否则仍然可能出现id和name冲突的问题。
  • 如果事件名称包含特殊字符,需要进行转义,以避免HTML解析错误。
  • 在实际应用中,可以使用更复杂的方法来生成唯一的id和name,例如使用UUID。

总结

在动态生成的HTML元素中添加交互功能时,需要特别注意元素的id和name属性,以避免冲突和功能错乱。本教程以一个动态生成HTML表格并为其添加星级评分功能的例子,详细讲解了如何通过修改id和name属性来解决评分错乱的问题。希望本教程能够帮助你更好地构建动态Web应用。

以上就是为动态生成的HTML表格实现星级评分功能的详细内容,更多请关注其它相关文章!


# 以避免  # 淘宝关键词排名解密  # 专业短视频seo技巧  # 公司手机网站推广电话  # 深圳网站关键词优化教程  # 贺州企业网站建设如何  # 安吉seo整站优化方案  # 山洪灾害防治网站建设  # 里水网站建设方案  # 顺德网站建设公司流程  # 成都网站互联网推广  # 容器内  # 拖拽  # 的是  # css  # 首页  # 为其  # 自定义  # 第二个  # 复选框  # 信息系统  # yy  # html元素  # 浏览器  # html  # java  # javascript 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 包子漫画官方网站在线链接-包子漫画在线阅读平台主页地址  蛙漫安全无毒 官方认证的绿色入口  在J*a中如何捕获IndexOutOfBoundsException_索引越界异常防护方法说明  QQ邮箱在线登录平台 QQ邮箱个人邮箱网页版入口  中兴Axon42Ultra怎样在文件App筛图_iPhone中兴Axon42Ultra文件App筛图【图片筛选】  React中useState与局部变量:理解组件状态管理与渲染机制  黑猫投诉统一入口官网 消费者权益保护投诉平台  Win11怎么关闭快速启动_Win11彻底关机设置教程  如何在CSS中使用浮动制作导航栏_float实现水平菜单  特斯拉自动驾驶房车计划曝光 原型车将于2027年亮相  J*aScript中正确使用querySelectorAll与复杂CSS选择器  快手网页版在线登录 快手网页版官网入口快速访问  CSS子选择器:如何区分并样式化嵌套列表的子层级  QQ邮箱网页版入口 QQ邮箱官方邮箱登录通道  Lar*el头像管理:图片缩放与旧文件删除的最佳实践  J*aScript中管理异步API调用:确保操作顺序与数据一致性  Composer如何处理Git子模块(submodule)依赖_Composer与Git Submodule的对比与选择  必由学官网快捷入口 必由学网页版在线学习平台  CSS条件样式无法按设备触发怎么排查_media条件语句正确设置解决触发问题  漫蛙MANWA漫画主页官方入口 漫蛙漫画最新在线阅读地址  网易大神怎么保存别人动态的图片_网易大神动态图片保存方法  windows10怎么查看硬盘序列号_windows10硬盘id查询命令  在J*a中如何开发在线活动报名与管理系统_活动报名管理项目实战解析  4399网页游戏电脑版全新入口 4399电脑端在线玩指南  手机屏幕碎了但能正常使用怎么办 手机外屏碎裂的修复建议  《明末:渊虚之羽》设计师谈设计角色:那会刚毕业 充满激情  红果短剧网页版官网入口 官方最新网址发布  python3时间如何用calendar输出?  包子漫画官方网站阅读入口-包子漫画在线漫画官网直达链接  126邮箱手机版登录官网2026_126手机邮箱免费入口最新  在Blazor WebAssembly应用中动态注入客户端特定指标代码的策略  漫蛙2在线漫画入口 漫蛙正版漫画网页版直达  vivo手机互传视频怎么操作_vivo手机互传视频详细传输方法  Pyrogram与g4f集成:异步编程实践与常见错误解决  邮政快递单号查询入口 邮政快递物流信息在线查询入口  taptap防沉迷怎么解除 taptap解除健康系统限制说明【2025最新】  谷歌google账号怎么注册账号 谷歌账号注册官方流程  Highcharts 雷达图径向轴标签定制指南:利用多Y轴实现数值标注  如何为你的Composer包编写自动化测试_集成PHPUnit到Composer的scripts工作流  微信怎么把收藏的内容分类管理 微信收藏内容标签分类方法  WordPress插件开发:正确注册卸载钩子与避免常见陷阱  Go语言JSON解析深度指南:动态访问与结构体映射实践  处理动态列数据:J*a ArrayList的正确初始化与字符累加教程  c++ dfs和bfs代码 c++深度广度优先搜索算法  钉钉视频会议声音异常如何处理 钉钉会议音频修复技巧  c++如何使用Catch2编写单元测试_c++简洁易用的BDD风格测试框架  聚水潭ERP登录页面入口 聚水潭ERP官网登录界面  限制HTML日期输入框的日期选择范围  蛙漫限时开放最深处链接_蛙漫全站漫画会员同款秒开地址  Composer的 "conflict" 字段有什么用_如何声明不兼容的包以避免依赖冲突 

搜索