JS消息传递

设定好消息格式如下:

let message = {
    "resourseId": "assetId",
    "childrenResourseIds": [],
    "topoId": "self.topoId",
    "InfoSource": "2D"
  }

如果在同一脚本中可以直接获取到对应的值。如下:

message.topoId

当我们向窗口发送消息让其他窗口接收到消息,需要通过

window.postMessage(message, "*");

此处要传对象而不是json字符串,否则在接收方无法通过消息体获取到对应key的值。

接收消息代码如下:

window.addEventListener(
    "message",
    function (e) {
      var data=e.data;
	  console.log(data);
	  console.log(data.topoId);
      console.log(e);
    },
    false
  );

2019.11.27更

当我们切换页面的时候,监听依然存在,第一浪费性能,第二可能影响后续的程序运行。所以我们要在切换页面之前将监听事件移除。

vue中移除代码如下:

beforeDestroy() {
    //在组件生命周期结束的时候销毁。
    console.log("dcvim移除函数");
    window.removeEventListener("message", this.ListernerHandle, false);
    console.log("dcvim移除结束");
  }

beforeDestroy是vue的声明周期函数,在页面被销毁前会被调用。注意:要移除监听,就要修改增加监听的函数形式。在增加监听的位置不可以使用匿名函数。且要确定在增加监听和移除监听的参数一样。

如:

 window.addEventListener("message", this.ListernerHandle, false);

研究了一下午,再加上有时候vue编译启动后时好时坏。第一次编译程序没有正常运行,当我在vue中加入log再次重新启动竟然好用了。领导说我是新手哪里没弄懂,搞错了,我表示很无奈。

最近做js心情超级差,寻思不懂的问题问下公司里做js的,可是都是回的不会,查百度。我惊呆了,程序员有这么冷漠吗。或者说做js的都这么冷漠吗?之前的公司互相探讨问题都能讲一下午,巴不得你来问我问题。也许是这个大公司的氛围就是这样吧,冰冷的办公室。努力,跳离这个圈!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值