Получите значение из нового всплывающего окна, щелкнув элемент с помощью Jquery

Я хочу получить значение из нового всплывающего окна, нажав на элемент в новом всплывающем окне. Мой код работает с первого раза после того, как я нажал кнопку. После перезагрузки страницы в новом всплывающем окне мой код не работает.

Индекс.html

<button id = "open-new-windows">TEST</button>

<script>
  $("#open-new-windows").click(function () {
    var w = window.open(
      "http://localhost/test/child.html",
      "TEST",
      "width=300,height=400"
    );

    w.addEventListener("load", function () {
      var html = $(w.document.body).find("ul");
      console.info(html.length); // return 1
      html.on("click", "li", function () {
        var a = $(this).text();
        alert(a);
      });
    });
  });
</script>

Child.html

<ul>
  <li>1</li>
  <li>2</li>
  <li>3</li>
  <li>4</li>
  <li>5</li>
  <li>6</li>
  <li>7</li>
</ul>

Я хочу получить значение после повторной загрузки страницы. Пожалуйста, помогите мне. Спасибо.

Прослушиватель событий очищается при перезагрузке открытого окна. Вы МОЖЕТЕ уйти, переместив функцию загрузки в отдельную функцию и запустив opener.functionName() из дочернего элемента.

mplungjan 19.03.2024 11:33
jsfiddle.net/wre6v5nk
react_or_angluar 19.03.2024 11:59
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
2
2
67
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Я предлагаю переместить прослушиватель кликов LI в child.html и начать общение с помощью API широковещательного канала:

index.html

<button id = "open-new-windows">TEST</button>

<script>
    const el = (sel, par = document) => par.querySelector(sel);

    el("#open-new-windows").addEventListener("click", (ev) => {
        window.open("http://localhost:3000/child.html", "TEST", "width=300,height=400");
    });

    const bc = new BroadcastChannel("comm");

    bc.addEventListener("message", (ev) => {
        // Do nothing if message is not from the expected origin:
        if ( ! /^http://localhost/.test(ev.origin)) return;
        // All OK: do something with the sent message:
        alert(ev.data);
    });
</script>

child.html

<ul>
    <li>This is LI 1</li>
    <li>This is LI 2</li>
    <li>This is LI 3</li>
    <li>This is LI 4</li>
    <li>This is LI 5</li>
    <li>This is LI 6</li>
    <li>This is LI 7</li>
</ul>

<script>
    const els = (sel, par = document) => par.querySelectorAll(sel);

    const bc = new BroadcastChannel("comm");

    const sendMessage = (ev) => {
        const elLI = ev.currentTarget;
        const text = elLI.textContent;
        bc.postMessage( text );
    };

    els("ul li").forEach(elLI => elLI.addEventListener("click", sendMessage) );
</script>

Таким образом, даже если вы обновите страницу child.html, она снова подключится к тому же каналу вещания.
См. здесь еще один пример

ПС:
отредактируйте приведенное выше http://localhost:3000/child.html, чтобы оно соответствовало вашей конфигурации.

Другие вопросы по теме