Javascript-форум (https://javascript.ru/forum/)
-   Internet Explorer (https://javascript.ru/forum/css-html-internet-explorer/)
-   -   SCRIPT3: Член группы не найден. (Edge) (https://javascript.ru/forum/css-html-internet-explorer/65465-script3-chlen-gruppy-ne-najjden-edge.html)

eugen81 20.10.2016 21:20

SCRIPT3: Член группы не найден. (Edge)
 
Всем доброго времени суток!
Задался тут целью сделать полифилл для IE, Edge с целью заставить нормально работать форму, у которой поля с атрибутом form могут быть вынесены за ее пределы. Всё работало хорошо, пока не начал вешать событие onclick на submit.
HTML:
<form id="test-form">
    <input name="hidden" value="hidden" type="hidden"/>
</form>
<label for="test-text">text:</label>
<input name="text" value="test" form="test-form" type="text" id="test-text">
<button form="test-form" type="submit" name="submit">Отправить</button>

JS:
(function () {
        var form = document.forms[0];
        var id = form.getAttribute('id');
        var selector = 'input[form="' + id + '"], textarea[form="' + id + '"], select[form="' + id + '"], button[form="' + id + '"]';
        var elements = document.querySelectorAll(selector);

        for (var k = 0; k < elements.length; k++) {
            var element = elements[k];
            if (element.type == 'submit' || element.type == 'image') {
                element.onclick = submitFix;
            } else {
                var hidden = document.createElement('input');
                hidden.name = element.name;
                hidden.type = 'hidden';
                hidden.value = element.value;
                form.appendChild(hidden);
                element.onchange = changeFix;
            }
        }

        function submitFix(event) {
            event.preventDefault();
            var form = document.getElementById(this.getAttribute('form'));
            if (this.name) {
                var hidden = form.querySelector('[type="hidden"][name="' + this.name + '"]');
                if (!hidden) {
                    hidden = document.createElement('input');
                    hidden.name = this.name;
                    hidden.type = 'hidden';
                    form.appendChild(hidden);
                }
                hidden.value = this.value;
            }
            form.submit(); // Ошибка "SCRIPT3: Член группы не найден."
        }

        function changeFix(event) {
            event.preventDefault();
            var form = document.getElementById(this.getAttribute('form'));
            var hidden = form.querySelector('[type="hidden"][name="' + this.name + '"]');
            hidden.value = this.value;
        }
    })();

Что интересно - до нажатия кнопки "Отправить"
document.forms[0].submit()

из консоли прекрасно работает, а после нажатия на кнопку - уже нет. Прошу помощи!

Aetae 20.10.2016 21:28

Лень разбираться, но в любом случае onclick - плохой вариант, вешать надо во-первых через addEventListener\attachEvent, а во-вторых на onsubmit.

eugen81 20.10.2016 21:35

Цитата:

Сообщение от Aetae (Сообщение 432393)
Лень разбираться, но в любом случае onclick - плохой вариант, вешать надо во-первых через addEventListener\attachEvent, а во-вторых на onsubmit.

Через addEventListener делал, результат тот же. И если кнопка вынесена из формы, то onsubmit работать не будет. А если кнопка внутри формы, то onsubmit не нужен.

eugen81 20.10.2016 21:46

Rise, так на клик и сделано

Lemme 20.10.2016 22:13

Rise, видимо, в ms тоже так подумали и правильно сделали "имхо".
http://www.w3schools.com/tags/att_button_form.asp

рони 20.10.2016 22:19

Цитата:

Сообщение от eugen81
name="submit"

:blink:

Aetae 20.10.2016 22:20

Попробуй убрать event.preventDefault(); и добавить в конце return false;

рони 20.10.2016 22:22

eugen81,
или хотябы так name="Submit"

eugen81 21.10.2016 06:34

рони,
Спасибо, дело было в name="submit" :blink: какая разница IE как я назову элемент?
Rise,
Lemme,
Если этот способ работает во всех остальных браузерах, значит это кому-то нужно. Пример выше - просто тест, реально на странице несколько форм, но элементы в ней располагаются согласно макету так, что запихать все элементы в свои формы сложно

рони 21.10.2016 07:02

Цитата:

Сообщение от eugen81
Если этот способ работает во всех остальных браузерах

:blink: с name="submit" какой браузер у вас работает???


Часовой пояс GMT +3, время: 02:22.