写在前面:

  • 环境:Vue3 + Konva + vite
  • 在绘制界面时踩坑,主要是关于 listening 属性的使用
  • 在绘制界面时,不免出现有内容重叠的情况,这会影响事件的触发

  • 使用设置listening属性可以允许事件穿透,默认为true不可穿透(示例如下)

    <template>
    <div>
    <div id="mybtn"></div>
    </div>
    </template> <script>
    import Konva from 'konva'; export default {
    data() {
    return {
    position: {
    posX: 0,
    posY: 0,
    },
    size: {
    width: 100,
    height: 50,
    },
    styles: {
    borderSize: 1,
    fontSize: 12,
    backgroundColor: '',
    fontColor: '#000',
    borderColor: '#000',
    opacity: 1,
    },
    btnText: 'Button',
    };
    },
    mounted() {
    this.initializeKonva();
    },
    methods: {
    initializeKonva() {
    const stage = new Konva.Stage({
    container: 'mybtn',
    width: this.size.width,
    height: this.size.height,
    }); const layer = new Konva.Layer();
    stage.add(layer); const button = new Konva.Rect({
    x: this.position.posX,
    y: this.position.posY,
    width: this.size.width,
    height: this.size.height,
    fill: this.styles.backgroundColor,
    stroke: this.styles.borderColor,
    strokeWidth: this.styles.borderSize,
    opacity: this.styles.opacity,
    }); const buttonText = new Konva.Text({
    x: this.position.posX,
    y: this.position.posY,
    width: this.size.width,
    height: this.size.height,
    text: this.btnText,
    fontSize: this.styles.fontSize,
    fontFamily: 'Arial',
    fill: this.styles.fontColor,
    align: 'center',
    verticalAlign: 'middle',
    listening: false, // 设置listening为false,允许事件穿透
    }); button.on('click', this.clickBtn); layer.add(button);
    layer.add(buttonText);
    layer.draw(); }, clickBtn() {
    console.log('clickBtn run');
    // 点击事件逻辑
    }
    },
    };
    </script> <style scoped>
    div {
    width: 100%;
    height: 100%;
    }
    </style>

Konva 内容重叠无法触发点击事件的解决方法的更多相关文章

  1. jquery无法为动态生成的元素添加点击事件的解决方法

    遇到 jquery无法为动态生成的元素添加点击事件,谷歌一下,整理一下解决方法如下: (<li>中间的元素是动态生成的), 现在想为<i>添加点击事件, 例子如下: <d ...

  2. Angular输入框内按下回车会触发其它button的点击事件的解决方法

    方法:给button按钮添加type=“botton”属性

  3. view.performClick()触发点击事件

    1.主要作用 自动触发控件的点击事件 2.界面的布局文件  activity_main.xml <RelativeLayout xmlns:android="http://schema ...

  4. 解决jQuery ajax动态新增节点无法触发点击事件的问题

    在写ajax加载数据的时候发现,后面添加进来的demo节点元素,失去了之前的点击事件.为什么点击事件失效,我们该怎么去解决呢? 其实最简单的方法就是直接在标签中写onclick="" ...

  5. 可以触发点击事件并变色的UILabel

    可以触发点击事件并变色的UILabel 谁说UILabel不能够当做button处理点击事件呢?今天,笔者就像大家提供一个改造过的,能够触发点击事件并变色的UILabel:) 效果图: 还能当做计时器 ...

  6. 解决JavaScript拖动时同时触发点击事件的BUG

    在做在线地图项目的时候,在给marker点绑定事件时,因为有点击事件click,同时又存在拖动dragEnd事件,首先没有重大缺陷,就是在用户在点击的时候,有时候本想是点击,但是他触发了drag的事件 ...

  7. 关于AJAX异步加载节点无法触发点击事件问题的解决方式

    做练习的过程中遇到一个问题,使用AJAX异步新增一个节点,无法触发点击事件,经过查阅之后知道一个方式,使用JS的委托事件,在此做一个记录. $(document).on('click', '.recr ...

  8. JS实现按下按键触发点击事件

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  9. vue中Enter触发登录事件和javascript中Enter触发点击事件

    created(){ window.addEventListener('keydown', this.handleKeyDown, true)//开启监听键盘按下事件 } 在methods中当keyC ...

  10. Echarts如何添加鼠标点击事件?防止重复触发点击事件

    Echarts如何添加鼠标点击事件? 1.通常我们只使用了以下代码,通过配置项和数据显示图表. var myChart = echarts.init(document.getElementById(' ...

随机推荐

  1. ansible系列(21)--ansible的变量注册Register

    1. 变量注册Register register 关键字可以将某个 task 任务结果存储至变量中,最后使用 debug模块 输出变量内容,可以用于后续排障: 示例一:register的基本使用: # ...

  2. ansible(9)--ansible的yum模块

    1. yum模块 功能:管理软件包,需要确认被管理端为红帽系列的,并且需要被管理端配置好yum源. 主要的参数如下: 参数 说明 name 指定安装软件包名或软件包URL state 指定yum对应的 ...

  3. VueJs创建网易音乐播放器和vueJs常见错误处理

    学习vuejs之后,总得自己上手写一些完整的应用,才能够更加了解各个结构与组件之间的运用. 下面从最基础的准备工作开始: 用vue-cli搭建vue应用:先确保自己已经安装Node环境. (1)Win ...

  4. node.js环境在Window和Mac中配置,以及安装cnpm和配置Less环境

    Node.js 和cnpm安装 最近准备学习vue.js,但首先需要配置电脑的环境.配置node.js. 1.在node(https://nodejs.org/en/)官网上下载安装node.js,两 ...

  5. avue组件自定义按钮/标题/内容/搜索栏

    话不多说 笔记直接分享!! 一.自定义crud搜索栏组件 <template slot-scope="scope" slot="provinceCodeSearch ...

  6. 微信H5分享不能展示卡片问题

    来源与微信开放社区 微信H5已成功接入,微信api以及配置项验证正常,通过手机微信里面链接打开页面进行分享,分享出去的还是链接, 需要从以下场景进入才可以正常分享卡片 从二维码进入 分享卡片进入 公众 ...

  7. Nginx的正向代理和反向代理

    1.Nginx代理 (1)Nginx出现的早期就是作为一个高性能的http.反向代理的web服务器. (2)同时它也提供了IMAP/POP3/SMTP服务,也就是电子邮件代理服务器. (3)它的特点就 ...

  8. ceph客户端配置自动挂载存储服务

    1. 安装支持ceph的内核模块 可选: centos/ubuntu: yum install -y ceph-common 或 apt install -y ceph-common 2. 拷贝认证密 ...

  9. jquery的筛选器

    <!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8 ...

  10. xv6 磁盘中断流程和启动时调度流程

    首发公号:Rand_cs 本文讲述 xv6 中的一些细节流程,还有对之前文中遗留的问题做一些补充说明,主要有以下几个问题: 一次完整的磁盘中断流程 进入调度器后的详细流程 sched 函数中的条件判断 ...