计算机网络之iframe内联框架跨域
- iframe框架同源下的数据调用
- iframe框架非同源下的数据传输
一、iframe框架同源下的数据调用
1.父窗口向子窗口获取数据
//html1父级窗口
<iframe src="./2.html"></iframe>
<script type="text/javascript">
var oIframe = document.getElementsByTagName('iframe')[0];
oIframe.onload = function(){
console.log(oIframe.contentWindow.a);//打印出:22a
}
</script>
//html2子级窗口
<script type="text/javascript">
var a = "22a";
</script>
2.子窗口向父窗口获取数据
//父级窗口
<iframe src="./2.html"></iframe>
<script type="text/javascript">
var a = "11a";
</script>
//子级窗口
<script type="text/javascript">
var a = "22a";
console.log(window.parent.a);//11a
</script>
注:
1.获取iframe内的window又多种方法,示例中采用获取iframe标签再通过contentWindow属性获取,是一种通用的写法。
标准浏览器:window.frames['iframe的name']。采用window上的frame属性然后通过内联框架的name属性获取。
IE专用:document.iframes[‘iframe的name’].contentWindow。
docuemtn.iframes[i].contentWindow。(i表示索引)
2.获取父级窗口的对象:window.parent
3.获取顶级窗口的对象:window.top
4.获取属于自己的窗口对象:window.self
二、iframe框架非同源下的数据传输(跨域传输)
1.通过hash值向子窗口传送数据:父窗口代码==》
//父级窗口
<iframe src="http://xxx.cn/iframe/2.html"></iframe>
<script type="text/javascript">
//实现每点击一次修改一次内联框架的hash值
var oIframe = document.getElementsByTagName('iframe')[0];
var a = 1;
var oSrc = oIframe.src;
document.onclick = function(){
oIframe.src = oSrc + "#" + a;
a++;
}
</script>
子窗口代码==》
//子窗口
<script type="text/javascript">
//通过定时器时时获取父窗口修改的hash值(注意没修改时不获取)
var ohash = window.hash;//获取初始hash值
setInterval(function(){
if(ohash != window.location.hash){//判断时时hash值是否等于上一次的
console.log(window.location.hash);
ohash = window.location.hash;//将修改的hash值赋给ohash
}
},10);
</script>
这种做法是可以实现时时的跨域内联框架的数据传输,但是定时器的性能损耗太大,并不适合。而且这种方法也仅仅适应父级窗口向子级窗口传输数据。
2.通过window.name实现跨域内联框架数据传输(需要借助一个同源的页面),解决子窗口向父级窗口传输数据:
//子窗口有一个变量
var a = 1;
window.name = a;
在非同源的父级窗口(跨域获取子窗口变量的值的方法)
<iframe src="http:xxx.cn\iframe\2.html"></iframe>
<script type="text/javascript">
//实现每点击一次修改一次内联框架的hash值
var oIframe = document.getElementsByTagName('iframe')[0];
oIframe.src = "3.html";//3是一个同源同源的页面
oIframe.onload = function(){
console.log(oIframe.contentWindow.name);
}
</script>
计算机网络之iframe内联框架跨域的更多相关文章
- 第48天学习打卡(HTML 行内元素和块元素 列表 表格 视频和音频 页面结构分析 iframe内联框架 表单语法 )
行内元素和块元素 块元素 无论内容多少,该元素独占一行 (p.h1-h6) 行内元素 内容撑开宽度,左右都是行内元素的可以排在一行 (a.strong.em...) 列表 什么是列表 ...
- 重写iframe内联框架中的内容
重写iframe内联框架中的内容,不使用src指向页面url,主动写入HTML代码: var ifr = document.getElementById("CMBC-certificatio ...
- __x__(14)0906第三天__<iframe> 内联框架 引入有一个外部html页面
在现实开发中,不推荐使用内联框架,因为<iframe></iframe>中的内容不会被搜索引擎检索. 在特殊情况中,如内网项目,不用放在互联网上时,可以使用<iframe ...
- Iframe内联框架
iframe:内联框架标签,用于在网页中任意的位置嵌入另一个网页 <iframe src="url地址"> </iframe> iframe标签的常用属性 ...
- iframe与主框架跨域相互访问方法
iframe 与主框架相互访问方法 http://blog.csdn.net/fdipzone/article/details/17619673/ 1.同域相互访问 假设A.html 与 b.htm ...
- iframe与主框架跨域相互访问方法【转】
转自:http://blog.csdn.net/fdipzone/article/details/17619673 1.同域相互访问 假设A.html 与 b.html domain都是localho ...
- iframe 内联框架
Iframe - 设置高度和宽度 height 和 width 属性用于规定 iframe 的高度和宽度. 属性值的默认单位是像素,但也可以用百分比来设定(比如 "80%"). 实 ...
- iframe内嵌页面——跨域通讯
<template> <div class="act-form"> <iframe :src="src" ref=" ...
- 如何利用JQuery获取iframe内联框架对象?
parent.$("#iframeID").get(0).contentWindow; 父.$("选择器").get(0).contentWindow; get ...
随机推荐
- 网站注册与登录使用 bcrypt与 passport 双重验证 解释
网站在登录前,需要进行注册收集用户基本信息,bcrypt 提供密码加密验证的方法,但是使用不正确,会给初学者带来各种问题. bcrypt 的安装: npm i bcrypt 经过测试,经常安装不成功, ...
- U盘启动盘安装Windows10操作系统详解
没有装过系统的同学,总以为装系统很神秘?是专业技术人员干的事情.今天我们来看看怎么借助常用的U盘装上全新的win10系统. 准备材料: 软件软碟通,可上官网下载:https://cn.ultraiso ...
- 「Python」为什么Python里面,整除的结果会是小数?
2018-06-08 参考资料:Python学习笔记(4)负数除法和取模运算 先来看三个式子(!这是在Python3.0下的运算结果): 输出结果: ‘//’明明是整除,为什么结果不是整数,而会出现小 ...
- 配置SSH(GNS3)
实验拓扑: -------------------------------------------配置IP过程不多啰嗦了 1.SSH配置过程 这里是用GSN3模拟器做的 --------------- ...
- http面试准备
从http的角度深入分析一次web请求: 1.在浏览器输入一个url地址如www.baidu.com 2.请求DNS把这个域名解析成对应的IP地址(DNS域名解析过程看上篇博客) 3.根据这个IP地址 ...
- Django学习笔记(3)--模板
模板 在实际的页面大多是带样式的HTML代码,而模板是一种带有特殊语法的html文件,这个html文件可以被django编译,可以传递参数进去, 实现数据动态化.在编译完成后,生成一个普通的html文 ...
- 转载:教你分分钟搞定Docker私有仓库Registry
一.什么是Docker私有仓库Registry 官方的Docker hub是一个用于管理公共镜像的好地方,我们可以在上面找到我们想要的镜像,也可以把我们自己的镜像推送上去.但是,有时候我们的服务器无法 ...
- Wonder 1.0正式版发布-----WebGL 3D引擎和编辑器
介绍 我们很荣幸地向大家发布Wonder 1.0正式版!免费.开源,不用注册,直接打开在线编辑器即可使用! Wonder是web端3D开发的解决方案,包括引擎.编辑器,致力于打造开放.分享.互助的生态 ...
- Python--day05(数字、字符串、列表)
1.数字类型 1. 整型 int long(py2) 2. 小数 float 3. 布尔 bool 4. 复数 complex 2. 字符串类型 只能存一个值,是有序的不可变类型 2. ...
- H5活动页开发有关
活动页开发流程 针对各种节日各种活动,临时定稿开发的活动页,往往时间安排都比较急 ---- 产品定下需求方向 UI实现设计稿 1. 草图和交互逻辑定稿=>多少个页面,每个页面表达的含义以及和用户 ...