17370845950

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

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

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

问题描述

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

原因分析

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

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

    
    
    
    
    

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

解决方案

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

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

$(".table tbody tr").last().after(
    '' +
    '' +
    '' + eventname + '' +
    '' + eventdate + '' +
    '' + eventloc + '' +
    '' + eventdesc + '' +
    '' + eventauthor + '' +
    '' +
    ''
    + ''
);

在这个修改后的代码中,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(
            '' +
            '' +
            '' + eventname + '' +
            '' + eventdate + '' +
            '' + eventloc + '' +
            '' + eventdesc + '' +
            '' + eventauthor + '' +
            '' +
            ''
            + ''
        );

        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应用。