据我所知,只有加载到DOM中的对象才能被选择器操纵。这在下面的示例中说明,当单击按钮时,它的单击处理程序未成功尝试选择要加载的页面中的元素并在之前更改它的html。我推测,因为在链接页面加载到DOM之前触发了单击处理程序,所以选择器不会影响该元素。
我的问题是,有什么方法可以实例化一个外部的html块并在将它插入DOM之前对其进行操作。
script_1.js:
$(document).ready(function () {
$("#testButton").click(function () {
$("#externalPageDiv").html("hello world");
});
});
外部页面html:
<head>
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<link rel="stylesheet" href="http://code.jquery.com/mobile/1.1.0-rc.1/jquery.mobile-1.1.0-rc.1.min.css"
/>
<script src="http://code.jquery.com/jquery-1.7.1.min.js"></script>
<script src="http://code.jquery.com/mobile/1.1.0-rc.1/jquery.mobile-1.1.0-rc.1.min.js"></script>
<script src="script_1.js"></script>
</head>
<body>
<div data-role="page" id="externalPage" data-add-back-btn="true">
<div data-role="content" id="externalPageContent">
<div id="externalPageDiv"></div>external page</div>
</div>
</body>
主页Html:
<head>
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<link rel="stylesheet" href="http://code.jquery.com/mobile/1.1.0-rc.1/jquery.mobile-1.1.0-rc.1.min.css"
/>
<script src="http://code.jquery.com/jquery-1.7.1.min.js"></script>
<script src="http://code.jquery.com/mobile/1.1.0-rc.1/jquery.mobile-1.1.0-rc.1.min.js"></script>
<script src="script_1.js"></script>
</head>
<body>
<div data-role="page" id="internalPage_1" data-add-back-btn="true">
<div data-role="content" id="internalPageContent_1">
<a href="externalPage.html" id="testButton" data-role="button" rel="external">Page Change</a>
</div>
</div>
<div data-role="page" id="mainPage" data-add-back-btn="true">
<div data-role="content" id="mainPageContent">Main Page</div>
</div>
</body>
答案 0 :(得分:15)
我正在纠正我的错误评论。 是的,您可以执行这样的 ,但是阅读jQuery文档时,可以说代码是插入到DOM http://api.jquery.com/jQuery/#jQuery2中的。所以,即使下面的代码似乎也没有在DOM中插入任何东西,它确实插入了。
试试这个:
var codeToProcess = "<div>" +
" <div id='myDiv1'>a</div>" +
" <div id='myDiv2'>b</div>" +
" <div id='myDiv3'>c</div>" +
"</div>";
var $toProcess = $( codeToProcess );
$toProcess.find( "div" ).addClass( "processed" );
// getting by id before insertion
alert( $toProcess.find( "#myDiv1" ).html() );
alert( $( "#myDiv1" ).html() ); // this will return null, since the divs
// were not yet added to the document
$toProcess.appendTo( "#container" );
// or $( "#container" ).html( $toProcess );
// getting by id after insertion
alert( $( "#myDiv2" ).html() );
jsFiddle:http://jsfiddle.net/davidbuzatto/me7T3/
修改强>
要从外部文件插入代码,您可以使用加载功能。你可以在这里看到一个例子:http://jsfiddle.net/davidbuzatto/zuFsc/注意,在这个例子中,我使用echo服务os jsFiddle来模拟外部文件。看看How do you output a view file as an ajax response in Java?和http://api.jquery.com/load/
答案 1 :(得分:8)
您可以使用javascript手动创建未插入DOM层次结构的DOM元素,您可以在将它们插入DOM之前尽可能多地操作它们。
但是,如果您在解析HTML页面之前尝试操作由页面HTML创建的DOM元素,则无法执行此操作。 DOM元素在那时不存在,因此除非您按照第一段中的描述手动创建它们,否则无需操作。
某些操作仅适用于插入DOM hieararchy的DOM元素,例如document.getElementById()
,但其他方法可用于不在主层次结构中的DOM,例如item.getElementsByClassName()
item
是不在DOM层次结构中的DOM元素。
在jQuery中,默认上下文是文档,因此像$(".foo")
这样的简单选择器操作只会搜索DOM文档层次结构中的DOM元素。但是,如果您传递特定的上下文$(".foo", item)
,那么jQuery选择器将搜索该上下文,而不是主文档。