Estou criando um cursor personalizado anexando dinamicamente um elemento div no hook useEffect quando o componente é montado e é definido para seguir o mouse usando ouvintes de eventos. No entanto, dois divs estão sendo renderizados — um segue corretamente o mouse, enquanto o outro fica no canto superior esquerdo da viewport.
import { useRef, useEffect, useState } from "react"
function Pcanvas({width, height, pixelSize}){
const [canvasColor, setCanvasColor] = useState("#dcdcdc")
const [pencilSize, setPencilSize] = useState(pixelSize)
const canvasRef = useRef(null)
var mousePressed = false
function mouseCursor(){
const cursor = document.createElement("div")
cursor.className = 'cursor'
cursor.style.backgroundColor = 'black'
cursor.style.width = pencilSize + 'px'
cursor.style.height = pencilSize + 'px'
cursor.style.position = 'absolute';
cursor.style.display = 'block';
cursor.style.zIndex = 999;
cursor.style.pointerEvents = 'none';
document.body.appendChild(cursor)
console.log(cursor.getBoundingClientRect().y)
}
function handleMouseMov(event){
const cursor = document.getElementsByClassName('cursor')[0]
console.log(cursor.getBoundingClientRect().y)
if(cursor){
cursor.style.top = event.clientY-(pencilSize/2) + 'px'
cursor.style.left = event.clientX-(pencilSize/2) + 'px'
}
}
function handleMouseLeave(event){
const cursor = document.getElementsByClassName('cursor')[0]
if(cursor){
cursor.style.display = 'none'
}
}
function handleMouseEnter(event){
const cursor = document.getElementsByClassName('cursor')[0]
if(cursor){
cursor.style.display = 'block'
}
}
useEffect(() => {
const canvas = canvasRef.current
mouseCursor()
document.body.addEventListener('mouseenter', handleMouseEnter)
document.body.addEventListener('mousemove', handleMouseMov)
document.body.addEventListener('mouseleave', handleMouseLeave)
return(() => {
document.body.removeEventListener('mouseenter', handleMouseEnter)
document.body.removeEventListener('mousemove', handleMouseMov)
document.body.removeEventListener('mouseleave', handleMouseLeave)
})
}, [pencilSize])
return(
<></>
)
}
export default Pcanvas
Você deve evitar
createElement
, especialmentegetElementsByClassName
ao usar React.Deixe o componente renderizar o
div
, então use umuseRef
para alterar qualquer estilo quando necessário.