Arhn - архитектура программирования

Javascript: добавление дочерних элементов с функциями: FireFox против Chrome

У меня есть тестовая страница, основанная на проблеме, с которой я столкнулся:

<!DOCTYPE html>
<html>
    <head>
        <title>Test</title>
        <style type="text/css">
            #selectDiv { display: inline; }
        </style>
        <script type="text/javascript">
            function changeOption(args) {
                var sel = document.createElement("select");
                var opt1 = document.createElement("option");
                var opt2 = document.createElement("option");
                var opt3 = document.createElement("option");
                opt1.value = "opt1";
                opt1.appendChild(document.createTextNode("Option 1"));
                sel.appendChild(opt1);
                opt2.value = "opt2";
                opt2.appendChild(document.createTextNode("Option 2"));
                sel.appendChild(opt2);
                opt3.value = "opt3";
                opt3.appendChild(document.createTextNode("Option 3"));
                sel.appendChild(opt3);

                // working on FireFox, not on Chrome
                opt1.onclick = function() {changeOption()}
                opt2.onclick = function() {changeOption()}
                opt3.onclick = function() {changeOption()}

                document.getElementById("selectDiv").appendChild(sel);
            }
        </script>
    </head>
    <body>
        <h1>This is a test.</h1>
        <div id="selectDiv">
        <select id="test_select1" onchange="changeOption()">
            <option value="opt1">Option 1</option>
            <option value="opt2">Option 2</option>
            <option value="opt3">Option 3</option>
        </select>
        </div>
    </body>
</html>

В FireFox это работает так, как я и ожидал: каждый новый выбор создается с тремя вариантами; выбор одного создает новый выбор с тремя вариантами.

Но в Chrome он останавливается на втором выборе. То есть вновь созданный выбор, похоже, не получает функцию onclick. Первый выбор с радостью создает больше выборок, но это не то, что я ищу.

Safari ведет себя как Chrome, но этого и следовало ожидать, верно? Я пробовал версию jQuery, но она тоже не работает. Может кто-нибудь помочь мне здесь?


  • Вероятно, это как-то связано с тем, как браузеры обрабатывают указатели на обработчики событий. Вы можете исправить это, используя делегата, прослушивающего selectDiv. Я не уверен, используете ли вы jQuery или нет, поэтому реализация будет отличаться. 17.07.2015
  • он останавливается при втором выборе, первый выбор работает, потому что вы создали html. 17.07.2015
  • См. также этот вопрос 17.07.2015

Ответы:


1

Привяжите обработчик изменений к выбранному элементу, а не обработчик кликов к параметрам. Итак, это:

sel.onchange = function(){
   changeOption();
}

Вместо:

opt1.onclick = function() {changeOption()}
opt2.onclick = function() {changeOption()}
opt3.onclick = function() {changeOption()}

Скрипт: https://jsfiddle.net/c1kmtnfd/

17.07.2015
  • Вы не объяснили почему. Почему события onclick не работают в Chrome? 17.07.2015
  • Во-первых, это плохая практика. Событие щелчка не будет вызвано, если я перейду на вкладку и изменю параметр с помощью клавиатуры — событие изменения при выборе будет. Я ищу спецификацию реализации Chrome onclick. 17.07.2015
  • Я не нашел официальной документации от Chrome; однако присоединение обработчика onchange к выбору определенно более надежно в кросс-браузерном режиме. Вот таблица реализованных событий для элемента option в разных браузерах: webbugtrack.blogspot.ca/2007/11/ 17.07.2015
  • Да. Перейдите к скрипке, которую я разместил в Firefox и Chrome, и убедитесь сами. 17.07.2015
  • Извините, а где это? 17.07.2015
  • Эй, это работает! Но у меня нет... О, вы добавили onchange() в выбор, а не опцию... моя ошибка! 17.07.2015
  • Вы пытаетесь найти решение в коде, который вы разместили, или в другой базе кода? 17.07.2015
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..