Я хочу получить значение из нового всплывающего окна, нажав на элемент в новом всплывающем окне. Мой код работает с первого раза после того, как я нажал кнопку. После перезагрузки страницы в новом всплывающем окне мой код не работает.
Индекс.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>
Я хочу получить значение после повторной загрузки страницы. Пожалуйста, помогите мне. Спасибо.



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


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