电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

JS實現iframe中子父頁面跨域通訊的方法分析

瀏覽:78日期:2024-05-19 15:01:11

本文實例講述了JS實現iframe中子父頁面跨域通訊的方法。分享給大家供大家參考,具體如下:

在非跨域的情況下,iframe中的子父頁面可以很方便的通訊,但是在跨域的情況下,只能通過window.postMessage()方法來向其他頁面發送信息,其他頁面要通過window.addEventListener()監聽事件來接收信息;

#跨域發送信息#window.postMessage()語法

otherWindow.postMessage(message, targetOrigin, [transfer]); otherWindow 其他窗口的一個引用,寫的是你要通信的window對象。 例如:在iframe中向父窗口傳遞數據時,可以寫成window.parent.postMessage(),window.parent表示父窗口。 message 需要傳遞的數據,字符串或者對象都可以。

targetOrigin 表示目標窗口的源,協議+域名+端口號,如果設置為“*”,則表示可以傳遞給任意窗口。在發送消息的時候,如果目標窗口的協議、域名或端口這三者的任意一項不匹配targetOrigin提供的值,那么消息就不會被發送;只有三者完全匹配,消息才會被發送。例如: window.parent.postMessage(’hello world’,’http://xxx.com:8080/index.html’) 只有父窗口是http://xxx.com:8080時才會接受到傳遞的消息。

[transfer] 可選參數。是一串和message 同時傳遞的 Transferable 對象,這些對象的所有權將被轉移給消息的接收方,而發送一方將不再保有所有權。我們一般很少用到。

#跨域接收信息

需要監聽的事件名為'message'

window.addEventListener(’message’, function (e) { console.log(e.data) //e.data為傳遞過來的數據 console.log(e.origin) //e.origin為調用 postMessage 時消息發送方窗口的 origin(域名、協議和端口) console.log(e.source) //e.source為對發送消息的窗口對象的引用,可以使用此來在具有不同origin的兩個窗口之間建立雙向通信})#示例Demo

示例功能:跨域情況下,子父頁面互發信息并接收。

父頁面代碼:

<body> <button onClick='sendInfo()'>向子窗口發送消息</button> <iframe src='http://192.168.2.235/son.html'></iframe> <script type='text/javascript'> var info = { message: 'Hello Son!' }; //發送跨域信息 function sendInfo(){ var sonIframe= document.getElementById('sonIframe'); sonIframe.contentWindow.postMessage(info, ’*’); } //接收跨域信息 window.addEventListener(’message’, function(e){alert(e.data.message); }, false); </script></body> 子頁面代碼

<body> <button onClick='sendInfo()'>向父窗口發送消息</button> <script type='text/javascript'> var info = { message: 'Hello Parent!' }; //發送跨域信息 function sendInfo(){ window.parent.postMessage(info, ’*’); } //接收跨域信息 window.addEventListener(’message’, function(e){alert(e.data.message); }, false); </script></body>

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關于JavaScript相關內容可查看本站專題:《JavaScript操作DOM技巧總結》、《JavaScript頁面元素操作技巧總結》、《JavaScript事件相關操作與技巧大全》、《JavaScript查找算法技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript錯誤與調試技巧總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 柔软云母板-硬质-水位计云母片组件-首页-武汉长丰云母绝缘材料有限公司 | 光伏家 - 太阳能光伏发电_分布式光伏发电_太阳能光伏网 | ISO9001认证咨询_iso9001企业认证代理机构_14001|18001|16949|50430认证-艾世欧认证网 | 卷筒电缆-拖链电缆-特种柔性扁平电缆定制厂家「上海缆胜」 | 杭州中策电线|中策电缆|中策电线|杭州中策电缆|杭州中策电缆永通集团有限公司 | 台式核磁共振仪,玻璃软化点测定仪,旋转高温粘度计,测温锥和测温块-上海麟文仪器 | 西安烟道厂家_排气道厂家_包立管厂家「陕西西安」推荐西安天宇烟道 | 垃圾压缩设备_垃圾处理设备_智能移动式垃圾压缩设备--山东明莱环保设备有限公司 | 电线电缆厂家|沈阳电缆厂|电线厂|沈阳英联塑力线缆有限公司 | 重庆LED显示屏_显示屏安装公司_重庆LED显示屏批发-彩光科技公司 重庆钣金加工厂家首页-专业定做监控电视墙_操作台 | 开平机_纵剪机厂家_开平机生产厂家|诚信互赢-泰安瑞烨精工机械制造有限公司 | 玻璃钢型材_拉挤模具_玻璃钢拉挤设备——滑县康百思 | 硅胶制品-硅橡胶制品-东莞硅胶制品厂家-广东帝博科技有限公司 | 全国国际化学校_国际高中招生_一站式升学择校服务-国际学校网 | 安徽净化工程设计_无尘净化车间工程_合肥净化实验室_安徽创世环境科技有限公司 | 超声波清洗机_超声波清洗机设备_超声波清洗机厂家_鼎泰恒胜 | 西安烟道厂家_排气道厂家_包立管厂家「陕西西安」推荐西安天宇烟道 | 拖鞋定制厂家-品牌拖鞋代加工厂-振扬实业中国高端拖鞋大型制造商 | 东莞韩创-专业绝缘骨架|马达塑胶零件|塑胶电机配件|塑封电机骨架厂家 | 美侍宠物-专注宠物狗及宠物猫训练|喂养|医疗|繁育|品种|价格 | 河北凯普威医疗器材有限公司,高档轮椅系列,推车系列,座厕椅系列,协步椅系列,拐扙系列,卫浴系列 | 捷码低代码平台 - 3D数字孪生_大数据可视化开发平台「免费体验」 | 沥青车辙成型机-车托式混凝土取芯机-混凝土塑料试模|鑫高仪器 | 薄壁轴承-等截面薄壁轴承生产厂家-洛阳薄壁精密轴承有限公司 | 雾度仪_雾度计_透光率雾度仪价格-三恩时(3nh)光电雾度仪厂家 | 北京银联移动POS机办理_收银POS机_智能pos机_刷卡机_收银系统_个人POS机-谷骐科技【官网】 | 一氧化氮泄露报警器,二甲苯浓度超标报警器-郑州汇瑞埔电子技术有限公司 | 专业的新乡振动筛厂家-振动筛品质保障-环保振动筛价格—新乡市德科筛分机械有限公司 | 博博会2021_中国博物馆及相关产品与技术博览会【博博会】 | 上海单片机培训|重庆曙海培训分支机构—CortexM3+uC/OS培训班,北京linux培训,Windows驱动开发培训|上海IC版图设计,西安linux培训,北京汽车电子EMC培训,ARM培训,MTK培训,Android培训 | 深圳快餐店设计-餐饮设计公司-餐饮空间品牌全案设计-深圳市勤蜂装饰工程 | 深圳昂为官网-气体分析仪,沼气分析仪,动态配气仪,气体传感器厂家 | 顶空进样器-吹扫捕集仪-热脱附仪-二次热解吸仪-北京华盛谱信仪器 | 天津次氯酸钠酸钙溶液-天津氢氧化钠厂家-天津市辅仁化工有限公司 | 济南铝方通-济南铝方通价格-济南方通厂家-山东鲁方通建材有限公司 | 二次元影像仪|二次元测量仪|拉力机|全自动影像测量仪厂家_苏州牧象仪器 | 盐水蒸发器,水洗盐设备,冷凝结晶切片机,转鼓切片机,絮凝剂加药系统-无锡瑞司恩机械有限公司 | 华禹护栏|锌钢护栏_阳台护栏_护栏厂家-华禹专注阳台护栏、楼梯栏杆、百叶窗、空调架、基坑护栏、道路护栏等锌钢护栏产品的生产销售。 | 多功能真空滤油机_润滑油全自动滤油机_高效真空滤油机价格-重庆润华通驰 | 上海刑事律师|刑事辩护律师|专业刑事犯罪辩护律师免费咨询-[尤辰荣]金牌上海刑事律师团队 | 【星耀裂变】_企微SCRM_任务宝_视频号分销裂变_企业微信裂变增长_私域流量_裂变营销 |