在没有iframe的情况下嵌入外部页面?

时间:2011-12-08 15:25:38

标签: javascript asp.net html iframe embed

有没有办法在不使用iframe的情况下嵌入外部网页?我可以访问这两个站点,我只希望嵌入内容的页面根据嵌入的内容调整大小(它会随着时间的推移而改变,并且可以在多个站点上)。

谢谢!

编辑:我认为任何类型的AJAX都不会起作用,因为它是跨站点的,并且JavaScript不允许你加载非现场内容(据我所知)。

6 个答案:

答案 0 :(得分:41)

您可以使用jquery加载外部页面:

<script>$("#testLoad").load("http://www.somesite.com/somepage.html");</script>
<div id="testLoad"></div>
//would this help

答案 1 :(得分:32)

或者你可以使用object标签:

http://jsfiddle.net/7MaXx/

<!--[if IE]>
<object classid="clsid:25336920-03F9-11CF-8FD0-00AA00686F13" data="http://www.google.be">
<p>backup content</p>
</object>
<![endif]-->

<!--[if !IE]> <-->
<object type="text/html" data="http://www.flickr.com" style="width:100%; height:100%">
<p>backup content</p>
</object>
<!--> <![endif]-->

答案 2 :(得分:2)

问题很好,但答案是:这取决于那个。

如果其他网页不包含任何表单或文字,例如,您可以使用CURL方法提取确切内容,然后在您的页面上显示。你可以不使用iframe来做到这一点。

但是,如果要嵌入的页面包含例如表单,则它将无法正常工作,因为表单处理在该站点上。

答案 3 :(得分:2)

这样的事情怎么样?

<?php
$URL = "http://example.com";
$base = '<base href="'.$URL.'">';
$host = preg_replace('/^[^\/]+\/\//', '', $URL);
$tarray = explode('/', $host);
$host = array_shift($tarray);
$URI = '/' . implode('/', $tarray);
$content = '';
$fp = @fsockopen($host, 80, $errno, $errstr, 30);
if(!$fp) { echo "Unable to open socked: $errstr ($errno)\n"; exit; } 
fwrite($fp,"GET $URI HTTP/1.0\r\n");
fwrite($fp,"Host: $host\r\n");
if( isset($_SERVER["HTTP_USER_AGENT"]) ) { fwrite($fp,'User-Agent: '.$_SERVER

["HTTP_USER_AGENT"]."\r\n"); }
fwrite($fp,"Connection: Close\r\n");
fwrite($fp,"\r\n");
while (!feof($fp)) { $content .= fgets($fp, 128); }
fclose($fp);
if( strpos($content,"\r\n") > 0 ) { $eolchar = "\r\n"; }
else { $eolchar = "\n"; }
$eolpos = strpos($content,"$eolchar$eolchar");
$content = substr($content,($eolpos + strlen("$eolchar$eolchar")));
if( preg_match('/<head\s*>/i',$content) ) { echo( preg_replace('/<head\s*>/i','<head>'.

$base,$content,1) ); }
else { echo( preg_replace('/<([a-z])([^>]+)>/i',"<\\1\\2>".$base,$content,1) ); }
?>

答案 4 :(得分:1)

为什么不使用PHP!它是所有服务器端的:

<?php print file_get_contents("http://foo.com")?>

如果您拥有这两个站点,则可能需要在服务器端使用完整的头部声明来确认此事务。工作得很漂亮。

答案 5 :(得分:1)

HTML Imports是Web组件的一部分,也是将HTML文档包含在其他HTML文档中的一种方法。见http://www.html5rocks.com/en/tutorials/webcomponents/imports/