gpt4 book ai didi

javascript - 是否可以在将 jQuery 创建的元素插入 DOM 树之前获取其 HTML?

转载 作者:可可西里 更新时间:2023-11-01 13:36:30 26 4
gpt4 key购买 nike

这是我得到的:

gridComplete: function() {
var doneButton = $('<input>', {
type: 'button',
value: 'Done',
click: function() {
alert("Done!");
}
});

console.log("HTML:", doneButton.html());

var ids = $(this).jqGrid('getDataIDs');
var self = this;
_.each(ids, function(id) {
$(self).jqGrid('setRowData', id, {
MarkDone: doneButton.html()
});
});
}

如果我只是尝试插入 doneButton 对象,jqGrid 单元将呈现 [object Object] 而不是实际的按钮。因此,我可以推断它需要原始 HTML。但是,doneButton.html() 返回一个空字符串...大概是因为我还没有将 doneButton 对象附加到文档上。

使用 jQuery 有什么技巧吗?我更喜欢使用更简洁/更安全的语法来生成 HTML 标记,但我可以这样做:

gridComplete: function() {
var doneButtonHtml = "<input type='button' value='Done' onclick=\"alert('Done');\" />";

var ids = $(this).jqGrid('getDataIDs');
var self = this;
_.each(ids, function(id) {
$(self).jqGrid('setRowData', id, {
MarkDone: doneButtonHtml
});
});
},

按预期呈现按钮。

最佳答案

您从按钮中得到一个空字符串,因为 html() 返回内部 HTML。

您可能需要 doneButton.get(0).outerHTML

关于javascript - 是否可以在将 jQuery 创建的元素插入 DOM 树之前获取其 HTML?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15665281/

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