Button으로 Resizable 구현하기

2024. 6. 4. 18:47·Stack/Next.js
반응형

프로젝트 도중 Resizable 구현

이전에 Draggable 을 구현한것 처럼 아래와 같은 코드로 구현을 해보았다.

import { RefObject } from 'react';
import styles from './resizeButton.module.css';

interface ResizeButtonProps {
  resizableRef: RefObject<HTMLDivElement>;
}

const ResizeButton = ({ resizableRef }: ResizeButtonProps) => {
  const resize = (pageX: number, pageY: number) => {
    if (resizableRef.current) {
      const rect = resizableRef.current.getBoundingClientRect();
      const newWidth = pageX - rect.left;
      const newHeight = pageY - rect.top;
      resizableRef.current.style.width = `${newWidth}px`;
      resizableRef.current.style.height = `${newHeight}px`;
    }
  };

  const onMouseMove = (e: MouseEvent) => {
    resize(e.pageX, e.pageY);
  };

  const onMouseUp = () => {
    document.removeEventListener('mousemove', onMouseMove);
    document.removeEventListener('mouseup', onMouseUp);
  };

  const onMouseDown = () => {
    console.log('클릭');
    document.addEventListener('mousemove', onMouseMove);
    document.addEventListener('mouseup', onMouseUp);
  };

  return 
	(
    	<div className={styles.resize_button} onMouseDown={onMouseDown}></div>
    );
};

export default ResizeButton;

onMoseDown : 마우스 클릭시 이벤트 실행

onMoseUp : 마우스 클릭을 땔 시에 실행

onMoseMove : 마우스를 움직일때 resize를 실행

resize : 참조한 ref의 크기를 마우스의 변경정도 만큼 변경시킴

반응형

'Stack > Next.js' 카테고리의 다른 글

Three.js 화면 조정하기 Next.js 한스푼을 더해서  (1) 2024.06.26
Draggable 구현하기  (0) 2024.06.04
Next.js metadata 다루는 방식의 변  (1) 2024.05.14
Next Image 사용하는 방법  (1) 2024.05.14
📘 Next.js 에 markdown 설치 하기  (1) 2024.05.09
'Stack/Next.js' 카테고리의 다른 글
  • Three.js 화면 조정하기 Next.js 한스푼을 더해서
  • Draggable 구현하기
  • Next.js metadata 다루는 방식의 변
  • Next Image 사용하는 방법
WHITE_FROST
WHITE_FROST
개발공부리뷰블로그
    반응형
  • WHITE_FROST
    하얀하얀IT
    WHITE_FROST
  • 전체
    오늘
    어제
    • 분류 전체보기 (119)
      • Stack (43)
        • Next.js (7)
        • React (12)
        • React-Native (15)
        • TypeScript (0)
        • Python (2)
        • JavaScript (2)
        • Android (1)
        • DB (2)
        • JAVA (1)
      • Obsidian (1)
      • AI (3)
      • AI Tools (0)
      • Tools (0)
      • Mac (0)
      • Error (7)
      • 알고리즘 정리 (6)
      • 알고리즘 문제풀이 (46)
      • 공부일상 (4)
      • 개발 도구 & 라이브러리 (0)
      • 정보처리기사 (0)
      • 기타 (6)
      • Tip (2)
  • 블로그 메뉴

    • 홈
    • 태그
    • 미디어로그
    • 위치로그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    코테
    알고리즘
    D2
    Next.js
    react-native-maps
    react-native
    오블완
    프로그래머스
    ReactHook
    React Hooks
    react
    error
    java
    코테준비
    javascript
    React-Native cli
    mongodb cloud
    리액트네이티브
    Python
    hooks
    SWEA
    d1
    reactnative
    티스토리챌린지
    백준
    mongoDB Atlas
    Expo
    코딩테스트
    ios
    boj
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.5
WHITE_FROST
Button으로 Resizable 구현하기
상단으로

티스토리툴바