跨源通信--postMessage用法

发送方:

function toEDC () {
  var edcObj = {
    adminUserVo: sessionStorage.getItem('userInfo'),
    token: sessionStorage.getItem('Admin-Token'),
    englishNameList: sessionStorage.getItem('englishNameList'),
    deseaseItem: sessionStorage.getItem('deseaseItem')
  }
  openEDC(edcObj)
}
function openEDC (edcObj) {
  const edcLoginUrl = http://localhost:52071/#/login
  const win = window.open(edcLoginUrl)
  window.addEventListener('message', e => {
    if (e.data.type === 'hello') {
      win.postMessage({ type: 'message', message: edcObj }, '*')
    }
  })
}

接收方:

receiveDH() {
			window.addEventListener('message', e => {
				if (e.data.type === 'message') {
					const data = e.data.message
					locals.setUserToken(data.token)
					this.setUserInfo(data.adminUserVo)
					this.setUserRauthority(data.englishNameList || [])
					localStorage.setItem('deseaseItem', data.deseaseItem)
					this.setIsReruitment(0)
					this.$router.push({
						name: 'TesteeList', 
						query: {
							// researchId: '1448889094275260417'
							researchId: JSON.parse(data.deseaseItem).edcSearchId
						}
					})
				}
				this.loading = false
			})
			window.opener.postMessage({ type: 'hello', message: 'ready' }, '*')
		}

注意:
此应用不可关闭发送方页面,当打开新页面的时候,发送方开始发送,接收方开始接受

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值