javascript - 附加一个在生产中不起作用的表

标签 javascript jquery ajax twitter-bootstrap

我正在使用 Bootstrap 创建一个网站,其中一个表的行已删除,并在按下按钮后重新填充了新数据。它在 Visual Studio 的 Google Chrome 设置中的测试环境中工作,但在实时服务器上部署后,该表将留空,并且在从 Web 访问时不会附加。 AJAX 调用正在运行,因为表外的字段正在更新,所以我认为这可能是测试 Chrome 和实时 Chrome 之间的 Java 脚本问题。这是我的第一个网站,所以我什至不确定如何测试一个特定的实时应用程序。有谁知道是什么原因造成的,或者有人能指出我正确的方向吗?提前致谢!

表格:

<div class="row">
    <table id="dt_products" class="table table-striped">
        <thead>
            <tr>
                <th class="text-center">Product ID</th>
                <th class="text-center">Price</th>
                <th class="text-center">Margin</th>
            </tr>
        </thead>
        <tbody>
            @if (Model.Products.Any())
            {
                for (var i = 0; i < 12; i++)
                {
                    <tr>
                        <td class="text-center">@Html.DisplayFor(m => m.Products[i].ProductID)</td>
                        <td class="text-center">@Html.TextBoxFor(m => m.Products[i].Price, "{0:c}")</td>
                        <td class="text-center">@Html.TextBoxFor(m => m.Products[i].Margin, "{0:c}")</td>
                    </tr>
                }
            }
        </tbody>
    </table>
</div>

AJAX 调用:

$(function () {
    $("#ProductDate").change(function () {
        var $productValue = $("#ProductDate").val(),
            $startDate = $(".productReleaseDate"),
            $pID = { iD: $productValue };
            $('#dt_products tbody tr').remove();
            $.ajax({
                type: "GET",
                url: '@Url.Action("GetProducts", "Sales")',
                data: $pID,
                success: function (data) {
                    //Fill data
                    var pattern = /Date\(([^)]+)\)/;
                    var results = pattern.exec(data[0].ProductDate);
                    var $dt = new Date(parseFloat(results[1]));
                    $startDate.text(($dt.getMonth() + 1) + "/" + $dt.getDate() + "/" + $dt.getFullYear());
                    for (var i = 0; i < data.length; i++) {
                        var row = $('<tr></tr>');

                        idCell = $('<td class="text-center"></td>').append(data[i].ProductID);
                        row.append(idCell);

                        idCell = $('<td class="text-center"></td>').append(Number(data[i].Price).toFixed(2));
                        row.append(idCell);

                        idCell = $('<td class="text-center"></td>').append(data[i].Margin);
                        row.append(idCell);

                        $('#dt_products tbody').append(row);
                    }
                }
            });
    }).change();
});

编辑:使用生产版本中的控制台错误,发现了 2 个错误。

Mixed Content: The page was loaded over HTTPS, but requested an insecure stylesheet http://fonts.googleapis.com/css?family=Source+Sans+Pro:400&subset=latin-ext,latin. This request has been blocked; the content must be served over HTTPS

1:2639 Uncaught TypeError: row.app is not a function
at Object.success (1:2639)
at j (jquery.min.js:2)
at Object.fireWith [as resolveWith] (jquery.min.js:2)
at x (jquery.min.js:4)
at XMLHttpRequest.b (jquery.min.js:4)

最佳答案

根据错误消息,您似乎在代码中的某处输入了 row.app 错字;可能你在某处不小心按下了返回键并将行一分为二。

我建议在您的项目中为 row.app 进行全局查找,以找到错误的确切位置。

关于javascript - 附加一个在生产中不起作用的表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45550103/

相关文章:

javascript - 如何从React Redux应用程序中的操作中获取 `this`?

php - 检查单击了哪个按钮

javascript - 变量中的 Jquery AJAX 响应 JSON。

php - 将 JSON 数据发送到 PHP 服务器(本地主机到托管站点)

javascript - JSON.stringify 奇怪的行为

javascript - 从 Node.js 调用 Scala.js 的正确方法是什么?

javascript - 是否可以将 firebase 的图片上传 "uploadTask.on"监听器变成一个 promise?

javascript - 制作 Javascript 简单的幻灯片

javascript - 使用 jQuery,是否可以让它检测某个链接类并打开它们?

javascript - 使用ajax将数据放入CKEditor字段