iframe父子组件传值

父组件:index.html

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<iframe src="iframe.html" width="200" height="200" id="iframe_demo"></iframe>
		<input type="button" name="" id="" value="父向子传值" onClick="sendBtn()" />
	</body>
	<script type="text/javascript">
		// 父接受子的值
		/**
		 * 跨源通信-接收方
		 * @param {event}  = [value] 
		 * @param {function}  = [value] 
		 * @param {useCapture}  布尔可选 指定事件是否在捕获或冒泡阶段执行。
		 */
		window.addEventListener("message", function(data) {
			console.log('父收到的数据:', data.data);
		}, false);
		
		// 父向子传值
		function sendBtn() {
			let iframe = document.getElementById('iframe_demo');
			let json = {
				name:'你好我是父'
			};
			iframe.contentWindow.postMessage(json, '*');
		}
	</script>
</html>

  子组件:iframe.html

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<input type="button" name="" id="" value="子向父传值"  onClick="sendBtn()"/>
	</body>
	<script type="text/javascript">
	function sendBtn(){
		// 子向父传值
		/**
		 * 跨源通信-发送方
		 * @param {massage}  = [value] 
		 * @param {targetOrigin}  = [value] 
		 */
		let json = {
			name:'你好我是子'
		};
		window.parent.postMessage(json, '*');
	}
	// 子接收父的值
	window.addEventListener("message", function(data) {
		console.log('子收到的数据:', data.data);
	}, false);
	
		
	</script>
</html>

  

posted @ 2021-07-22 15:04  neo_o  阅读(412)  评论(0编辑  收藏  举报

愿你的生活只有诗和远方