Javascript document.write()之后的URL哈希修改
我通过jQueryAjax下载了整个html网页。我想用通过ajax下载的内容替换当前页面的内容。我是用document.write()完成的。它不能正常工作,因为每当我试图修改散列时,网页都会被重新加载 我知道在IE中需要一个iframe,但这不是问题所在,因为我使用jQuery历史插件。这个问题是由于使用了document.write(),但我不知道为什么 更新: index.php->主入口点,它下载JS代码,在散列后解析URL并调用request.php request.php->请求入口点。它返回网页 当我模拟对request.php的直接请求并且下载的网页更新哈希时,它工作正常 当我模拟对index.php的原始请求时,它不起作用(仅在FFox中),index.php通过request.php下载网页,下载的页面修改散列Javascript document.write()之后的URL哈希修改,javascript,jquery,html,Javascript,Jquery,Html,我通过jQueryAjax下载了整个html网页。我想用通过ajax下载的内容替换当前页面的内容。我是用document.write()完成的。它不能正常工作,因为每当我试图修改散列时,网页都会被重新加载 我知道在IE中需要一个iframe,但这不是问题所在,因为我使用jQuery历史插件。这个问题是由于使用了document.write(),但我不知道为什么 更新: index.php->主入口点,它下载JS代码,在散列后解析URL并调用request.php request.php->请求入
我使用document.write()将网页内容写入当前窗口。因此,问题在于修改“正在编写”文档中的哈希值。不要使用
document.write()
改为使用
$('your selector').html(您的html通过ajax获取)
我认为您不能修改整个html对象,因为这意味着删除对javascript脚本
标记的引用。我认为最好的选择是链接到request.php页面,或者更改body标记
$('body').html(response_html);
我同意harshath.jr的观点,不要使用
document.write()
将您指向iframe的个人是正确的。添加iframe,只需将src属性设置为正在获取的页面……您甚至不需要request.php
如果您真的想在不使用iframe的情况下加载html,您需要解析头部的元素并将其添加到文档中,还需要解析的内容并将其添加到当前页面主体中。但它不能保证正确显示。我认为iframe才是您真正想要的。问题是,当“您的选择器”是根节点时,它不起作用。内容是一个完整的网页,等等……在这种情况下,考虑使用iFrAME。请参见写入正文而不是html本身