Prevent row adding in html table ,on Duplicate Barcode

Analyst_SQL 3,551 Reputation points
2023-03-21T07:09:36.6866667+00:00

I am adding row into html table,

 <div class="row">
            <div style="display: inline-block;">
                <div>
                    @Html.LabelFor(model => model.Prdno, "Barcode", htmlAttributes: new { @class = "control-label col-md-4" })

                    @Html.EditorFor(model => model.Prdno, new { htmlAttributes = new { @class = "form-control col-md-10", @id = "Search_Prdno" } })
                    @Html.ValidationMessageFor(model => model.Prdno, "", new { @class = "text-danger" })
                </div>
            </div>
 function addrow() {
        $('#btnInsert').add(function () {
            var tbody = $('#DataInsert tbody');
            var tr = $('<tr></tr>');
            tr.append('<td>' + $('#Barcode_Bale').val() + '</td>');
            tr.append('<td>' + $('#Bale_Qty').val() + '</td>');
            tr.append('<td>' + $('#select2-3').text() + '</td>');
            tr.append('<td>' + $('#select2-3').val() + '</td>');

            tr.append('<td><input class="del" type="button" value="Delete" /></td>')
            // Checking Duplicate Barcode
            var items = ['<td>' + $('#Barcode_Bale').val() + '</td>'];
            var item = $('#Search_Prdno').val();

                if ($.inArray(item, items) != -1) // or if (items.indexOf(item) != -1)
                {
                    $('#spnMessage').html(item + ' found');
                }
                else {
                    $('#spnMessage').html(item + ' not found');
                }
        

            tbody.append(tr);


            //$("#Barcode_Bale").empty();
            //$("#select2-3").empty();


            $('#Search_Prdno').val(null);
            $('#Search_Prdno').focus();

        });

i want to prevent duplicate Barcode to add in HTML table.

I tried below ,but it is not working.

  // Checking Duplicate Barcode
            var items = ['<td>' + $('#Barcode_Bale').val() + '</td>'];
            var item = $('#Search_Prdno').val();

                if ($.inArray(item, items) != -1) // or if (items.indexOf(item) != -1)
                {
                    $('#spnMessage').html(item + ' found');
                }
                else {
                    $('#spnMessage').html(item + ' not found');
                }
        

User's image

ASP.NET
ASP.NET
A set of technologies in the .NET Framework for building web applications and XML web services.
3,455 questions
C#
C#
An object-oriented and type-safe programming language that has its roots in the C family of languages and includes support for component-oriented programming.
10,847 questions
0 comments No comments
{count} votes

Accepted answer
  1. Lan Huang-MSFT 29,246 Reputation points Microsoft Vendor
    2023-03-21T08:19:36.9966667+00:00

    Hi @akhter hussain,

    You can use jquery selectors:

    $('#DataInsert tr:contains("' + $("#Barcode_Bale").val() + '")').length

     $('#btnInsert').add(function () {
            if ($('#DataInsert tr:contains("' + $("#Barcode_Bale").val() + '")').length > 0) {
                alert("found duplicate values");
            }
            else {
                var tbody = $('#DataInsert tbody');
                var tr = $('<tr></tr>');
                tr.append('<td>' + $("##Barcode_Bale").val() + '</td>');
                tr.append('<td>' + $('#Bale_Qty').val() + '</td>');
                tr.append('<td>' + $('#select2-3').text() + '</td>');
                tr.append('<td>' + $('#select2-3').val() + '</td>');
    
                tr.append('<td><input class="del" type="button" value="Delete" /></td>')
                tbody.append(tr);
            }
    

    Best regards,
    Lan Huang


    If the answer is the right solution, please click "Accept Answer" and kindly upvote it. If you have extra questions about this answer, please click "Comment".
    Note: Please follow the steps in our documentation to enable e-mail notifications if you want to receive the related email notification for this thread.

    0 comments No comments

0 additional answers

Sort by: Most helpful

Your answer

Answers can be marked as Accepted Answers by the question author, which helps users to know the answer solved the author's problem.