Skip to main content

HTML5 Canvas 移动滚动和原生事件与 Konva

默认情况下,Konva 会阻止所有指针交互在舞台上的默认行为。
这将防止在移动设备上拖放形状时意外滚动页面。

但在某些情况下,您可能希望保留浏览器事件的默认行为。在这种情况下,您可以将形状的 preventDefault 属性设置为 false

说明:如果您在移动设备上,请尝试通过每个矩形滚动页面。
绿色 - 应该会阻止默认行为(不滚动页面)。
红色 - 将保留默认行为(滚动应有效)。

import Konva from 'konva';

const stage = new Konva.Stage({
  container: 'container',
  width: window.innerWidth,
  height: window.innerHeight,
});

const layer = new Konva.Layer();
stage.add(layer);

// 绿色矩形 - 将阻止滚动
const greenRect = new Konva.Rect({
  x: 50,
  y: 50,
  width: 100,
  height: 600,
  fill: 'green',
  stroke: 'black',
  strokeWidth: 4,
});
layer.add(greenRect);

// 红色矩形 - 将不会阻止滚动
const redRect = new Konva.Rect({
  x: 200,
  y: 50,
  width: 100,
  height: 600,
  fill: 'red',
  stroke: 'black',
  strokeWidth: 4,
  preventDefault: false,
});
layer.add(redRect);