gpt4 book ai didi

jquery - 如何在 jquery 的 .html() 中执行 jquery/javascript 代码

转载 作者:行者123 更新时间:2023-12-01 00:24:45 25 4
gpt4 key购买 nike

在 jQuery.html() 中,我想执行以下脚本。

$("#row1").html("<td id="cellId"><script>if (selectedStr) {var elem = $(\"#cellId\");       
$(elem).bind(\"onRefresh\", function() {loadColor(selectedStr); storeStr(selectedStr);});$(elem).trigger(\"onRefresh\");) }</script><td>")

要求:

我有一个 testPage.jsp,其中包含带有单元格的表格。当选择特定单元格并单击“提交”按钮时,将打开一个弹出窗口。在弹出的页面中,更改了一些数据,并通过ajax进行处理。生成的 ajax 响应必须动态设置到父行。 ajax 响应构建了要设置的全部内容。这就是我失败的地方。Ajax 响应将是这样的。 <td>.....<td> <td>.....<td> <td>content<script>...</script></td> <td>.....<td> <td>content<script>...</script></td>...此外,“selectedStr”是testPage.jsp中的一个javascript全局变量。

问题:1.“selectedStr is undefined”是浏览器错误消息。我无法获取对全局变量的引用。2. 元素绑定(bind)没有发生。

我尝试使用 jQuery.getScript()、jQuery.globalEval、jQuery.eval。我无法理解 JQuery 的 {{html}}。

谢谢!

最佳答案

不要将所有内容都放入脚本中,而是在内存中构建元素,然后在添加到 DOM 之前向其中添加事件处理程序。

$td = $("<td></td>").attr("id", "cellId")
.bind("onRefresh", function() {
if (selectedStr) {
loadColor(selectedStr);
storeStr(selectedStr);
}
})
.trigger("onRefresh");

$("#row1").html($td);

此外,请谨慎添加具有相同 Id 的多个 td 元素。

关于jquery - 如何在 jquery 的 .html() 中执行 jquery/javascript 代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8806207/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com