HTML5 Canvas 移动滚动和原生事件与 Konva
默认情况下,Konva
会阻止所有指针交互在舞台上的默认行为。
这将防止在移动设备上拖放形状时意外滚动页面。
但在某些情况下,您可能希望保留浏览器事件的默认行为。在这种情况下,您可以将形状的 preventDefault
属性设置为 false
。
说明:如果您在移动设备上,请尝试通过每个矩形滚动页面。
绿色 - 应该会阻止默认行为(不滚动页面)。
红色 - 将保留默认行为(滚动应有效)。
- Vanilla
- React
- Vue
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);
import { Stage, Layer, Rect } from 'react-konva'; const App = () => { return ( <Stage width={window.innerWidth} height={window.innerHeight}> <Layer> <Rect x={50} y={50} width={100} height={600} fill="green" stroke="black" strokeWidth={4} /> <Rect x={200} y={50} width={100} height={600} fill="red" stroke="black" strokeWidth={4} preventDefault={false} /> </Layer> </Stage> ); }; export default App;
<template> <v-stage :config="stageSize"> <v-layer> <v-rect :config="greenRectConfig" /> <v-rect :config="redRectConfig" /> </v-layer> </v-stage> </template> <script setup> const stageSize = { width: window.innerWidth, height: window.innerHeight }; const greenRectConfig = { x: 50, y: 50, width: 100, height: 600, fill: 'green', stroke: 'black', strokeWidth: 4 }; const redRectConfig = { x: 200, y: 50, width: 100, height: 600, fill: 'red', stroke: 'black', strokeWidth: 4, preventDefault: false }; </script>