dongquan0024 2014-10-11 01:30
浏览 57
已采纳

以iframe为目标的网址的帖子显示在iframe的iframe中

This is a little bit confusing. I am trying to submit a url to an iframe on the same page. When I click submit, the iframe duplicates the current page, but the correct url is in the replicated iframe. I wonder if it goes on forever? The page that this is happening is http://www.4mobilesites.com and the code is below.

<div class="mobile-logo">
<H2>How does your website look on a Mobile Device?</h2>
<?php 
$keyurl = $_POST['siteurl'];
?>

<form method="post" target="mobileframe" >
Enter your website's URL: <input type="text" name="siteurl" value="http://" size="50"><br>
<input type="submit" value="VIEW">
</form><br>
<a name="iframe-1"></a>
<div class="theiframewrap"><iframe name="mobileframe" class="theiframeid" src="<?php echo "$keyurl"; ?>" id="mobileframe"></iframe></div></div>

If you submit a url in the form, then scroll down a bit in the iframe and squint, you will see the correct url in the iframe of the iframe.

  • 写回答

1条回答 默认 最新

  • dongpaipu8394 2014-10-11 01:49
    关注

    You can use the simple post form like this. I think whats causing it is because of the target attribute on that form. Its sending your whole page into the iframe.

    <?php
    $keyurl = '';
    if(isset($_POST['siteurl'])) {
        $keyurl = $_POST['siteurl'];
        echo $keyurl;
    }
    ?>
    
    <div class="mobile-logo">
        <H2>How does your website look on a Mobile Device?</h2>
        <form method="post">
            Enter your website's URL: <input type="text" name="siteurl" value="http://" size="50"><br>
            <input type="submit" value="VIEW" />
        </form><br>
        <a name="iframe-1"></a>
        <div class="theiframewrap">
            <iframe name="mobileframe" class="theiframeid" src="<?php echo $keyurl; ?>"></iframe>
        </div>
    </div>
    

    Alternatively, you could use only jquery for this:

    <div class="mobile-logo">
        <H2>How does your website look on a Mobile Device?</h2>
        <form method="post">
            Enter your website's URL: <input type="text" name="siteurl" value="http://" size="50"><br>
            <input type="submit" value="VIEW" />
        </form><br>
        <a name="iframe-1"></a>
        <div class="theiframewrap">
            <iframe name="mobileframe" class="theiframeid" src=""></iframe>
        </div>
    </div>
    
    <script src="//ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <script type="text/javascript">
    $(document).ready(function(){
    
        $('input[type="submit"]').on('click', function(e){
            e.preventDefault();
            var url = $('input[name="siteurl"]').val();
            $('.theiframeid').attr('src', url);
        });
    
    });
    </script>
    

    Important Note: Not all sites will allow you to put theirs on your iframe. (Yahoo's and others)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)