草庐IT

NT-DOM-NV

全部标签

javascript - 在页面 DOM 加载时收到通知(但在 window.onload 之前)

我知道有一些方法可以在页面主体加载时获得通知(在加载所有图像和第3方资源之前触发window.onload事件),但每个浏览器都不同.是否有在所有浏览器上执行此操作的明确方法?据我所知:DOMContentLoaded:在Mozilla、Opera9和最新的WebKit上。这涉及向事件添加监听器:document.addEventListener("DOMContentLoaded",[初始化函数],false);延迟脚本:在IE上,您可以发出带有@defer属性的SCRIPT标签,它只会在BODY标签结束后可靠地加载。轮询:在其他浏览器上,您可以继续轮询,但是否有标准的轮询对象,或者

javascript - IE 不允许动态创建的 DOM 'a' 元素上的 onClick 事件

我在使用InternetExplorer时遇到问题。我有一个链接,它复制了表单上的文件上传元素。重复的代码还会将超链接附加到重复的上传元素,该元素应该删除重复的元素,只需简单地删除此链接即可。问题是这段代码在firefox中运行良好,但在IE中根本无法运行。忘记代码是如何写出来的——我附加到元素的onClick事件根本没有触发!我正在函数中像这样创建删除链接元素:vara=document.createElement('a');a.setAttribute('href',"javascript:void(0);");a.setAttribute('class','delete');a.

javascript - 从加载了 iFrame 的 jQuery DOMWindow 访问父窗口的 DOM 对象

我有一个带有jQ​​ueryDOMWindow的网页,它从iFrame加载其内容。我需要从iFrame访问父窗口的元素。这可能吗?这是从我的主页打开的DOMWindow的配置:$('.AjaxDOMWindow').openDOMWindow({anchoredClassName:'DOMWindow',draggable:1,eventType:'click',height:500,loader:1,loaderHeight:16,loaderImagePath:'/js/jquery/DOMWindow/animationProcessing.gif',loaderWidth:17

javascript - 在(jquery)ajax 请求中获取当前脚本 DOM 对象

我有一个包含一些javascript的html组件。组件是模板引擎中的一个文件,所以可以使用在整个html页面的初始渲染中作为通过ajax请求呈现的独立htmljavascript应该应用于模板中的对象,即:Thisisitem13Thisisitem14$(document).ready(function(){$(HOW_DO_I_GET_PREVIOUS_ELEMENT???).someEffect(params)})我检查过thissimilarquestion但最好的答案似乎依赖于当前脚本是“脚本”变量中的最后一个脚本,因为下一个脚本尚未加载。如果我将html和js附加到aja

javascript - JS 更改了 DOM 后如何抓取内容?

我正在使用Mechanize,但如果Mechanize做不到,我愿意接受Nokogiri。我想在加载完所有脚本之后而不是之前抓取页面。我该怎么做? 最佳答案 我认为Nokogiri、Watir和PhantomJs是一个不错的选择:b=Watir::Browser.new(:phantomjs)b.gotoURLdoc=Nokogiri::HTML(b.html)生成的文档将在加载脚本后生成。phantomjs很好,因为不需要加载浏览器。 关于javascript-JS更改了DOM后如何抓

javascript - document.getElementById 是否返回事件的 dom 元素?

JavaScript中的document.getElementById是否返回事件的DOM元素?出于性能原因,我有兴趣知道 最佳答案 标准和“实时”之间的区别通常用于元素的列表。document.getElementById返回对DOM节点的单个对象引用。获取节点后,引用将始终指向同一节点。示例的HTML:以JS为例:varfoo,bar;foo=document.getElementById('foo');//getsthedivbar=document.getElementById('bar');//nullfoo.setAtt

javascript - 为什么 documentFragment 不比重复的 DOM 访问快?

我一直认为,出于性能原因,与其反复接触DOM,不如使用documentFragment来附加多个元素,然后将片段附加到文档中一次,而不是而不仅仅是将新元素一个接一个地重复添加到DOM中。我一直在尝试使用Chrome的开发工具来分析这两种方法,使用这个测试页:Addrows测试1使用此代码向表中追加50000个新行:letaddRows=document.getElementById('addRows');addRows.addEventListener('click',function(){for(letx=0;x在Chrome的时间轴工具中录制时单击按钮会产生以下输出:测试2使用此代

javascript - 使用 .Net 在服务器端加载 DOM 并执行 javascript

我想使用文档(字符串形式)或URL加载DOM,然后对其执行javascript函数(包括jquery选择器)。这将完全是服务器端,在进程中,没有客户端/浏览器。基本上我需要加载dom,然后使用jquery选择器和text()&typeval()函数从中提取字符串。我真的不需要操纵dom。我看过Jurassic和Jint等.Netjavascript引擎,但都不支持加载DOM,因此无法满足我的需要。如果存在非.Net解决方案(node.js、ruby等),我愿意考虑,但我更喜欢.Net。编辑下面是一个很好的答案,但目前我正在尝试不同的路线,我正在尝试将envjs移植到侏罗纪。如果我能让它

javascript - alert 和 confirm 函数是内置在 JavaScript 中,还是 DOM 的一部分?

alert和confirm函数是内置于JavaScript中的,还是它们是DOM的一部分?如果你能给我推荐一个引用资料,让我很容易分辨出哪些函数直接内置到JavaScript中,那么加分。 最佳答案 它们是通常称为DOMlevel0的一部分这不是任何标准的一部分。MDN有一个goodJavaScriptreference.它不包括不属于核心JS的对象(尽管网站上的其他部分确实涵盖了DOM和其他API)。 关于javascript-alert和confirm函数是内置在JavaScript

javascript - 使用索引从 jQuery 数组返回 jQuery 对象(而不是 DOM)

我有一个的jQuery数组s并且我只想将其中一个作为jQuery对象,以便我可以在其上串接其他方法。类似于$mySpans[2](返回一个字符串),或$mySpans.get(2),(直接返回DOM元素)。我知道这会起作用:$($mySpans[2]).someJQueryMethod(...);...不过好像有点多余。执行此操作的正确方法是什么? 最佳答案 像这样:$myspans.eq(2).method(); 关于javascript-使用索引从jQuery数组返回jQuery对象