JQuery Hide () не работает на динамически сгенерированном DIV - PullRequest
0 голосов
/ 10 июля 2019

Попытка скрыть динамически сгенерированный DIV с идентификатором lineID, который вызывается из aspx backend, но он не работает. Функция вызывается, но строка в функции 6 не скрывается при вызове функции 7.

lineArea - это в основном тело HTML, в котором нарисованы линии.

Код, который рисует линию

//show line connecting 2 nodes
    function displayInst6Line() {
        var calcNode = new calculateLine();
        $('.lineArea').line(calcNode.displayInst6LineX, calcNode.displayInst6LineY, calcNode.displayInst6LineX2, calcNode.displayInst6LineY, { color: line_colour, stroke: 5, zindex: line_zindex });           
         $('#lineID').show();
    }

 //hide line
    function displayInst7Line() {     
        var calcNode = new calculateLine();
        $('.lineArea').line(calcNode.displayInst6LineX, calcNode.displayInst6LineY, calcNode.displayInst6LineX2, calcNode.displayInst6LineY, { color: '#868e96', stroke: 5, zindex: line_zindex });
        $('#lineID').hide();
    }

Внутренний код, который выполняет вычисления для строки

        //math function to draw lines
    (function ($) {

        var helpers = {
            createLine: function (x1, y1, x2, y2, options) {

                // Check if browser is Internet Exploder ;)
                var isIE = navigator.userAgent.indexOf("MSIE") > -1;
                if (x2 < x1) {
                    var temp = x1;
                    x1 = x2;
                    x2 = temp;
                    temp = y1;
                    y1 = y2;
                    y2 = temp;
                }
                var line = document.createElement("div");
                line.id = "lineID";
                line.className = options.class;

                // Formula for the distance between two points
                // http://www.mathopenref.com/coorddist.html
                var length = Math.sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2));

                line.style.width = length + "px";
                line.style.borderBottom = options.stroke + "px " + options.style;
                line.style.borderColor = options.color;
                line.style.position = "absolute";
                line.style.zIndex = options.zindex;

                if (isIE) {
                    line.style.top = (y2 > y1) ? y1 + "px" : y2 + "px";
                    line.style.left = x1 + "px";
                    var nCos = (x2 - x1) / length;
                    var nSin = (y2 - y1) / length;
                    line.style.filter = "progid:DXImageTransform.Microsoft.Matrix(sizingMethod='auto expand', M11=" + nCos + ", M12=" + -1 * nSin + ", M21=" + nSin + ", M22=" + nCos + ")";
                } else {
                    var angle = Math.atan((y2 - y1) / (x2 - x1));
                    line.style.top = y1 + 0.5 * length * Math.sin(angle) + "px";
                    line.style.left = x1 - 0.5 * length * (1 - Math.cos(angle)) + "px";
                    line.style.transform = line.style.MozTransform = line.style.WebkitTransform = line.style.msTransform = line.style.OTransform = "rotate(" + angle + "rad)";
                }
                return line;
            }
        }


        $.fn.line = function (x1, y1, x2, y2, options, callbacks) {
            return $(this).each(function () {
                if ($.isFunction(options)) {
                    callback = options;
                    options = null;
                } else {
                    callback = callbacks;
                }
                options = $.extend({}, $.fn.line.defaults, options);

                $(this).append(helpers.createLine(x1, y1, x2, y2, options)).promise().done(function () {
                    if ($.isFunction(callback)) {
                        callback.call();
                    }
                });


            });
        };
        $.fn.line.defaults = {
            zindex: 10000,
            color: '#000000',
            stroke: "1",
            style: "solid",
            class: "line",
        };
    })(jQuery);

1 Ответ

1 голос
/ 10 июля 2019

Это говорит о том, что вы дублируете идентификаторы, вызывая helpers.createLine более одного раза. У вас не может быть более одного элемента с одинаковым идентификатором. Вся цель идентификаторов - быть уникальными идентификаторами.

jQuery оптимизирует $("#lineID") в (эффективно) $(document.getElementById("lineID")) и getElementById может возвращать только один элемент. Обычно это первый код с идентификатором, когда вы нарушаете правило «нельзя иметь более одного элемента с одинаковым идентификатором». Поэтому $("#lineID").hide(); скроет первый элемент с этим идентификатором (даже если он уже скрыт).

Вам нужно будет либо присвоить элементам разные идентификаторы, либо идентифицировать их по-другому. Или, если предполагается, что это только один из них, используйте remove вместо hide для фактического удаления элемента.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...