高德信息弹窗中放置第三方插件,echarts等自定义元素组件库等

首先了解下_Vue—组件实例之$el

![在这里插入图片描述](https://img-blog.csdnimg.cn/f42f7431a01c443383672fb503e5d2ce.png

  • 获取Vue实例的DOM元素,自mounted钩子函数开始生效,之前的钩子函数内无效。如下代码所示,Vue脚手架中,$el指向当前组件template模板中的根标签。
<template>
  <div id="root">
    <h1 @click="fn()">
      Lorem, ipsum 
    </h1>
  </div>
</template>
<script>
export default {
  methods: {
    fn() {
      console.log(this.$el); // <div id="root">...</div>
    }
  }
};
</script>

封装信息弹窗

根据上述我们就可以通过solt对信息弹窗内容的编辑,可以通过$el挂载到信息弹窗的option上就可以使用编写的第三方内容插件(代码如下)

初始化信息弹窗,并将$el挂载到content上面,内容就可以随意编辑,后续也是通过抛出this.instance弹窗对象,进行弹窗的事件处理,打开或关闭

    initInfowindow() {
      this.instance = this.createInstance();
      if (this.$el) {
        this.instance.setContent(this.$el);
      }
    },
    createInstance(option) {
      let instance = new AMap.InfoWindow({
        isCustom: true, // 使用自定义窗体
        autoMove: true,
        closeWhenClickMap: true,
        content: '',
        // 设置基点偏移
        offset: new AMap.Pixel(0, -300),
      });
      return instance;
    },
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值