出于某种原因,我无法让jQuery html()函数工作。我尝试了以下方法:
查找特定的 div:
var div = $("#divId");
结果:工作
测试我是否可以将它与 jQuery 一起使用:
alert($(div).attr("id"));
结果:作品;显示了 id
获取 div 中的 html:
alert($(div).html());
结果:不起作用;空警报
使用 innerHTML 获取 div 中的 html:
alert(document.getElementById($(div).attr("id")).innerHTML);
结果:作品;div 内容显示在警报中
实际代码:
$(document).ready(function(){
var autocomp = namespace('mx.autocomp');
autocomp.overlay = (function() {
var formId;
var $searchValueComp;
var $searchResultComp;
function init(inFormId, inSearchValue){
formId = inFormId;
$searchValueComp = $("#"+inFormId).find("[id$="+inSearchValue+"]");
$searchResultComp = $("#"+inFormId).find("[id$=searchResult]");
}
function handleOverlay(){
var fn = window[formId + "OverlayWid"];
var result = document.getElementById($searchResultComp.attr("id")).innerHTML;
if($searchValueComp.val().length==0){
fn.hide();
}
// Test - This does not work as I get an empty alert
alert($searchResultComp.html());
// Edit1: New test, this works.
// When I use this javascript, I start with initializing the script from the page
// using the "init(inFormId, inSearchValue)" function. The handleOverlay() function
// is called through the "oncomplete='mx.autocomp.overlay.handleOverlay();'" of a
// p:remoteCommand that executes a search in the db and then update the div called
// "searchResultComp".
//
// Only reason I can think of why the code below works is that the jQuery object $test
// is created after the div called "searchValueComp" has been updated by p:remoteCommand.
// However, I don't understand why the jquery object "searchValueComp" wouldn't have
// access to the same content as it should look for it first when the html() function
// is called. Or is the content of the div searchValueComp set immediately when the
// object is created in the "init" function?
var $test = $("#"+formId).find("[id$=searchResult]");
alert($test.html());
// I need to check if the div: "searchResultComp" has any content.
// As I don't get $searchResultComp.html() to work, I'm forced to
// use the "getElementById" way instead.
if(result.length==0){
fn.hide();
}else{
fn.show();
}
}
function print(text){
$("#textCheck").prepend(text + '\n');
}
return {
handleOverlay: handleOverlay,
init: init
};
})();
});
我究竟做错了什么?