参考:http://www.cnblogs.com/MaxIE/archive/2008/08/13/1266597.html

问题一:首先我们用iframe加载页面,第一个需要解决的问题是高度自适应的问题,有2个方法

第一个是:

<iframeid="iFramebox" name="iFramebox" width="100%"onload="this.height=iFramebox.document.body.scrollHeight"  frameborder="0"scrolling="no"  src='/templates/106/ + url + '?id=' +taskid + '></iframe>

这里需要加载的页面的url地址是url + '?id=' + tasked

第二个方法 :

/* 设置iframe高度自适应 */

        var _iframe = $("#contentContainer> iframe");

        if (_iframe[0].attachEvent) {    //attachEvent是IE的监听器

           _iframe[0].attachEvent("onload", function () {

                //iframe页面加载完成后,你需要写的code

SetIframeHeight(_iframe);

            });

        } else {

            _iframe[0].onload = function () {

                       //iframe页面加载完成后,你需要写的code

                SetIframeHeight(_iframe);

            };

        }

        function SetIframeHeight(iframe) {

            _iframe.height(document.frames ?_iframe[0].document.body.scrollHeight :_iframe[0].contentDocument.body.scrollHeight);

        }

获取iframe 的高度仅作参考:

function reinitIframe(){var iframe = document.getElementById("frame_content");
try{
var bHeight = iframe.contentWindow.document.body.scrollHeight;
var dHeight = iframe.contentWindow.document.documentElement.scrollHeight;
var height = Math.max(bHeight, dHeight);
iframe.height = height;
}catch (ex){}
}
window.setInterval("reinitIframe()", 200);

问题二:

如果iframe加载了某一个页面 a , 但是a 页面又重新指向到了b页面,那iframe如何自动跳转到新页面b呢 ?

这种情况需要用到异步加载获取新地址,也介绍2种方法:

方法一:

$.get(url +'?id=' + taskid, function (data) {

        $iframeBox.attr("src", data);

});

说明: url为取得的a页面的地址,data为新指向的b页面的地址,然后把之前页面中的iframe的src地址进行修改,$iframeBox.attr("src",data)

方法二:也是用异步的方式,传递A 页面的url,type设置为”GET”,

$.ajax({

        url: url + '?id=' + taskid,

        async: false,

        type: "GET",

        data: "",

        success: function (data) {

            $iframeBox.attr("src",data);

        }

    });

问题三:当iframe页面加载完成后,如果我需要对 iframe进来的页面里的标签引用并做一些必要的事情的时候,该如何处理呢?(如何实现在iFrame加载相应的aspx 完成后再操作contentDocument中的元素)

因为通过iframe引进来的页面是个独立的页面,在我们的页面中我们只能引用iframe标签,不能引用到iframe标签里面的任何标签,假如被iframe引入进来的页面里有个id为divHidden的标签,只能通过

$("#divHidden", $("iframe")[0].contentDocument);来获取,contentDocument属性以HTML对象返回框架容纳的文档,可以通过所有标准的DOM方法来处理被返回的对象。

这一部分的完成代码为:

/* load taskinformation {加¨?载?task的ì?详¨o细?信?息?é}   */

functionloadInformation(url, taskid) {

    $("#loadingInfo").show();

    var $iframeBox = $('<iframeid="iFramebox" name="iFramebox" width="100%"onload="this.height=iFramebox.document.body.scrollHeight" frameborder="0"scrolling="no" src='/templates/106/ + url + '?id=' + taskid +'></iframe>');

   $iframeBox.appendTo($("#serviceTogerther"));

    $.ajax({

        url: url + '?id=' + taskid,

        async: false,

        type: "GET",

        data: "",

        success: function (data) {

            $iframeBox.attr("src",data);

        }

    });

       var _iframe = $iframeBox;

        if (_iframe[0].attachEvent) {

           _iframe[0].attachEvent("onload", function () {

                getHiddenField();

                SetIframeHeight(_iframe);

            });

        } else {

        _iframe[0].onload = function () {

            getHiddenField();

            SetIframeHeight(_iframe);

        };

    }

    function SetIframeHeight(iframe) {

        _iframe.height(document.frames ?_iframe[0].document.body.scrollHeight :_iframe[0].contentDocument.body.scrollHeight);

    }

    function getHiddenField() {

        $("#loadingInfo").hide();

        var $hiddenInput = $("#divHiddeninput", $("iframe")[0].contentDocument);

        var $StatusInput =$("#StatusButton").find("input");

        var $hotlinks =$("#TaskDetailQuickLink .serviceHotLink .Links");

        var sb = $hiddenInput.eq(0).val();

        var fb = $hiddenInput.eq(1).val();

        var cb = $hiddenInput.eq(2).val();

        if (sb == 0) {$StatusInput.first().attr("disabled", "disabled"); } else {$StatusInput.first().removeAttr("disabled"); }

        if (fb == 0) {$StatusInput.eq(2).attr("disabled", "disabled"); } else {$StatusInput.eq(2).removeAttr("disabled"); }

        if (cb == 0) {$StatusInput.last().attr("disabled", "disabled"); } else {$StatusInput.last().removeAttr("disabled"); }

       $StatusInput.eq(1).removeAttr("disabled");

        /* Get the hot link number */

        $hotlinks.html("");

       $(".branding-tagline-normal,.branding-tagline-special",$("iframe")[0].contentDocument).each(function () {

            var title = $(this).text();

            $hotlinks.append('<ahref="javascript:void(0);">' + title + '</a>');

        });

        if($.trim($hotlinks.find("a").last().text()) != "Comment") {

            $hotlinks.append('<ahref="javascript:void(0);"> Comment </a>');

        }

    }

    /*

    $.get(url + '?id=' + taskid, function(data) {

        $iframeBox.attr("src", data);

    });

    */

    $(".serviceHotLink").show();

}

Iframe 在项目中的使用总结的更多相关文章

  1. 项目中踩过的坑之-sessionStorage

    总想写点什么,却不知道从何写起,那就从项目中踩过的坑开始吧,希望能给可能碰到相同问题的小伙伴一点帮助. 项目情景: 有一个id,要求通过当前网页打开一个新页面(不是当前页面),并把id传给打开的新页面 ...

  2. Jquery和Javascript 实际项目中写法基础-弹出窗和弹出层 (4)

     一.实际项目中有很多如下界面效果.    二.该效果可以归结为弹出窗或者弹出层来实现的,为什么这么说?看如下代码:      <!DOCTYPE html> <html> & ...

  3. 教你利用iframe在网页中显示天气

    来源:http://www.ido321.com/921.html css: 1: *{margin:0;padding:0;list-style-type:none;} 2: a,img{borde ...

  4. ckeditor编辑器在java项目中配置

    一.基本使用: 1.所需文件架包 A. Ckeditor基本文件包,比如:ckeditor_3.6.2.zip 下载地址:http://ckeditor.com/download 2.配置使用 A.将 ...

  5. RN 导入原有Xcode项目中,引入Pod依赖出现的问题与解决

    RN 导入原有Xcode项目中,引入Pod依赖出现的问题与解决 前言 最近学习React Native技术.将RN引入到原来Xcode项目中有一步:给原来Xcode项目添加所需要的Pod依赖 写好Po ...

  6. iOS项目中常见的文件

    html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,bi ...

  7. 关于父窗口获取跨域iframe子窗口中的元素

    这几天在项目中遇到,一个难点, 就是需要异步加载一个pdf插件, 同时又需要获取这个插件中的点击事件来生成用户的下载记录. 刚开始也是想了很多方法,网上搜的 格式1:$("#iframe的I ...

  8. js 自己项目中几种打开或弹出页面的方法

    自己项目中,几种打开或弹出页面的方法(部分需要特定环境下) var blnTop = false;//是否在顶层显示 ///动态生成模态窗体(通过字符串生成) ///strModalId:模态窗体ID ...

  9. 项目中使用http referer,为了盗取图片资源

    项目背景:因为图片的数据是爬取的别人的图片,而且保存的数据仅仅是图片地址链接,为了减少数据存储和服务器压力,但是这就引发一个问题,有的图片地址没有做防盗处理,可以随意的下载使用:但有些图片的服务器做了 ...

随机推荐

  1. JavaScript写一个拼图游戏

    拼图游戏的代码400行, 有点多了, 在线DEMO的地址是:打开: 因为使用canvas,所以某些浏览器是不支持的: you know: 为什么要用canvas(⊙o⊙)?  因为图片是一整张jpg或 ...

  2. Mysql-ERROR 1044 (42000): Access denied for user ''@'localhost' to database 'mysql'

    方法一:1.关闭mysql   # service mysqld stop2.屏蔽权限   # mysqld_safe --skip-grant-table   屏幕出现: Starting demo ...

  3. C#把datetime类型的日期转化成年月日或其他格式方法总结

    日期格式:yyyyMMdd HH:mm:ss(注意此字符串的字母大小写很严格) yyyy:代表年份MM:  代表月份dd:  代表天HH:  代表小时(24小时制)mm:  代表分钟ss:  代表秒D ...

  4. 【POJ 2187】Beauty Contest(凸包直径、旋转卡壳)

    给定点集的最远两点的距离. 先用graham求凸包.旋(xuán)转(zhuàn)卡(qiǎ)壳(ké)求凸包直径. ps:旋转卡壳算法的典型运用 http://blog.csdn.net/hanch ...

  5. 【BZOJ-3165】Segment 李超线段树(标记永久化)

    3165: [Heoi2013]Segment Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 368  Solved: 148[Submit][Sta ...

  6. Matlab读入含有特殊分隔符的文件(textread)

    笔者在此基础上进行运行,修改得到以下内容,希望大家给与补充: textread 基本语法是: [A,B,C,…] = textread(filename,format) [A,B,C,…] = tex ...

  7. 【poj3764】 The xor-longest Path

    http://poj.org/problem?id=3764 (题目链接) 今天的考试题,看到异或就有点虚,根本没往正解上想.. 题意 给出一棵带权树,请找出树上的一条路径,使其边上权值的异或和最大. ...

  8. UTF-8有签名和无签名的区别

    当有签名的UTF-8编码内容被解析器解析时,解析器直接根据签名即可判断出使用UTF-8编码来进行解析,当无签名时,解析器会根据内容的编码来进行判别.所以,有签名的将更容易被解析器以正确的编码方式进行解 ...

  9. C#检测驱动是否安装的问题

    #region 检测CCD驱动是否安装成功 string path = @"C:\WINDOWS\system32\drivers\UsbCamIF.sys"; //驱动的默认安装 ...

  10. python使用cookielib库示例分享

    Python中cookielib库(python3中为http.cookiejar)为存储和管理cookie提供客户端支持,下面是使用示例 该模块主要功能是提供可存储cookie的对象.使用此模块捕获 ...