当前位置: 首页 > news >正文

大连网站建设dl zw深圳网络营销策划

大连网站建设dl zw,深圳网络营销策划,营销型网站建设宣传语,上海招聘信息最新招聘2022你们好,我是金金金。 场景 笔者用的Vue3,引入了高德地图,version为2.0,场景如下: 在地图上根据经纬度度打点标记了一个位置,然后点击点标记弹出自定义信息窗体,右上角关闭按钮则是绑定了关闭自定…

你们好,我是金金金。

image.png

场景

笔者用的Vue3,引入了高德地图,version2.0,场景如下:

  • 在地图上根据经纬度度打点标记了一个位置,然后点击点标记弹出自定义信息窗体,右上角关闭按钮则是绑定了关闭自定义信息窗体的事件,当点击时:
  • 报错:closeInfo is not defined

在这里插入图片描述

在这里插入图片描述

排查

贴一下相关代码

  • 关闭自定义信息窗体的方法

在这里插入图片描述

  • 关闭按钮绑定的事件

在这里插入图片描述

可以看到关闭按钮是绑定了closeInfo这个函数的,那为什么报错closeInfo未定义呢?细心的小伙伴肯定也发现了为什么这里不是@click而是用onclick绑定事件呢

造成error的原因

  1. 为什么是用onclick而不能用@click

    • 原因是这些元素是作为字符串插入到 DOM 树中的,因此 Vue 的事件系统无法捕捉到它们并为其绑定事件处理器。在这种情况下,应该使用原生的 onclick 属性来添加事件监听器。

      Vue 在编译模板时,会自动为带有 v-on:click@click 的元素添加事件监听器。但是,这种机制依赖于 Vue 在渲染组件时能够控制和操作 DOM 元素。当直接在模板字符串中插入一个元素,并且这个元素需要绑定一个事件时,由于它是动态插入的,Vue 可能没有机会去处理这个元素的事件绑定,所以需要使用原生的 onclick 事件属性来绑定事件处理函数。这种方法不需要 Vue 处理,可以直接在 HTML 字符串中使用

  2. 为什么会报错closeInfo未定义呢?

    • closeInfo 方法是在 Vue 组件的 methods 中定义的,那么它默认只能在 Vue 组件管理的 DOM 元素中被调用。这也就是为什么会报错未定义的原因,如果直接在 HTML 字符串中使用 onclick 来绑定事件,那么这个方法需要被定义在全局作用域内。

解决

既然知道了函数报错未定义的原因是因为作用域相关的问题,把closeInfo挂载到window上,点击时就可以在原型链中找到该函数,我这里在钩子函数中将其挂载到window

在这里插入图片描述

测试

无报错,事件也能正常触发,和预期结果一致,自定义信息窗体被关闭

在这里插入图片描述

总结

重点就是涉及到一些原生知识,由于是直接在字符串里面插入的元素,所以脱离了Vue的一些控制,细心点也是很好解决的~

  • 编写有误还请大佬指正,万分感谢。
http://www.mmbaike.com/news/50362.html

相关文章:

  • 建设网站的网站叫什么百度总部在哪里
  • 怎样创建网站的代码如何在百度搜索到自己的网站
  • 南京模板做网站seo用什么论坛引流
  • 群晖 做网站深圳网络营销平台
  • 大学城网站开发公司电话上海市人大常委会
  • 做招聘网站软文营销策划方案
  • html5 视差滚动网站官网seo哪家公司好
  • 做网站数据库表设计广告推广投放平台
  • 响应式网站案列网络营销经典失败案例
  • 网站栏目建设手机端百度收录入口
  • 通过模版做网站关键词你们懂的
  • 没学过计算机开始学做网站网络舆情的网站
  • 免费建网站可信吗郴州seo网络优化
  • 徐州营销型网站制使服装网络营销策划书
  • 用dw制作购物网站首页怎么推广自己的产品
  • 柳城网站建设线下推广渠道有哪些方式
  • 企业营业执照查询北京seo关键词排名优化软件
  • 关于做网站的策划方案湖南网站建设seo
  • 单位建网站怎么做天津seo博客
  • 刷神马网站优化排名短视频培训要多少学费
  • 怎么拥有网站的所有权搜索引擎优化的流程是什么
  • wordpress手机端独立域名seo顾问服务公司
  • 2019为赌博网站做代理被判缓刑太原网站建设谁家好
  • 用jsp做校园网站怎样推广网站
  • 建设微信商城网站电子商务网店运营推广
  • 网站注册页面推广app的方法和策略
  • 做网站的语言有哪些优秀的营销策划案例
  • 重庆公司网站开发网络服务合同
  • 网站制作哪里好薇少儿编程培训机构排名前十
  • 网站开发怎么实现用户一对一发文字图片杭州百度代理公司