{"id":10410,"date":"2025-06-05T13:39:08","date_gmt":"2025-06-05T04:39:08","guid":{"rendered":"https:\/\/www.skyer9.pe.kr\/wordpress\/?p=10410"},"modified":"2025-06-05T15:44:04","modified_gmt":"2025-06-05T06:44:04","slug":"react-%eb%93%9c%eb%9e%98%ea%b7%b8-%ea%b0%80%eb%8a%a5%ed%95%9c-%ed%8c%9d%ec%97%85","status":"publish","type":"post","link":"https:\/\/www.skyer9.pe.kr\/wordpress\/?p=10410","title":{"rendered":"React &#8211; \ub4dc\ub798\uadf8 \uac00\ub2a5\ud55c \ud31d\uc5c5"},"content":{"rendered":"<h1>React &#8211; \ub4dc\ub798\uadf8 \uac00\ub2a5\ud55c \ud31d\uc5c5<\/h1>\n<h2>\uc758\uc874\uc131 \uc124\uce58<\/h2>\n<pre><code class=\"language-bash\">npm i react-draggable<\/code><\/pre>\n<h2>\uad6c\ud604<\/h2>\n<p>Dialog \uc640 DialogTitle \uc5d0 \uac01\uac01 \ucf54\ub4dc\ub97c \uc791\uc131\ud574\uc8fc\uba74 \ub41c\ub2e4.<\/p>\n<p>\ud31d\uc5c5 \ubfd0\ub9cc \uc544\ub2c8\ub77c <code>&lt;div&gt;<\/code> \uac19\uc740 \uac83\ub3c4 \ubc16\uc5d0\uc11c \uac10\uc2f8\uc11c \ub4dc\ub798\uadf8 \uac00\ub2a5\ud55c \ucef4\ud3ec\ub10c\ud2b8\ub85c \ub9cc\ub4e4\uc218 \uc788\ub294 \ub4ef \ud558\ub2e4.<\/p>\n<pre><code class=\"language-jsx\">import {\n    Dialog,\n    DialogTitle,\n    DialogContent,\n    DialogActions,\n    \/\/ .............\n    Paper\n} from &#039;@mui\/material&#039;;\nimport Draggable from &#039;react-draggable&#039;;\n\nfunction PaperComponent(props) {\n    return (\n        &lt;Draggable\n            handle=&quot;#draggable-dialog-title&quot;\n            defaultPosition={{ x: 0, y: 0 }}\n            position={null}\n            grid={[25, 25]}\n            scale={1}\n        &gt;\n            &lt;Paper {...props} \/&gt;\n        &lt;\/Draggable&gt;\n    );\n}\n\nconst [defaultPosition, setDefaultPosition] = useState({ x: 0, y: 0 });\n\n\/\/ ......\n    return (\n        &lt;Dialog\n            open={open}\n            onClose={onClose}\n            maxWidth=&quot;lg&quot;\n            fullWidth\n            PaperComponent={PaperComponent}\n            PaperProps={{\n                style: {\n                    transform: `translate(${defaultPosition.x}px, ${defaultPosition.y}px)`\n                }\n            }}\n        &gt;\n            &lt;DialogTitle id=&quot;draggable-dialog-title&quot; style={{ cursor: &#039;move&#039; }}&gt;\n                \uc81c\ud488 \uc120\ud0dd\n            &lt;\/DialogTitle&gt;<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>React &#8211; \ub4dc\ub798\uadf8 \uac00\ub2a5\ud55c \ud31d\uc5c5 \uc758\uc874\uc131 \uc124\uce58 npm i react-draggable \uad6c\ud604 Dialog \uc640 DialogTitle \uc5d0 \uac01\uac01 \ucf54\ub4dc\ub97c \uc791\uc131\ud574\uc8fc\uba74 \ub41c\ub2e4. \ud31d\uc5c5 \ubfd0\ub9cc \uc544\ub2c8\ub77c &lt;div&gt; \uac19\uc740 \uac83\ub3c4 \ubc16\uc5d0\uc11c \uac10\uc2f8\uc11c \ub4dc\ub798\uadf8 \uac00\ub2a5\ud55c \ucef4\ud3ec\ub10c\ud2b8\ub85c \ub9cc\ub4e4\uc218 \uc788\ub294 \ub4ef \ud558\ub2e4. import { Dialog, DialogTitle, DialogContent, DialogActions, \/\/ &#8230;&#8230;&#8230;&#8230;. Paper } from &#039;@mui\/material&#039;; import Draggable from &#039;react-draggable&#039;; function PaperComponent(props) { return (\u2026 <span class=\"read-more\"><a href=\"https:\/\/www.skyer9.pe.kr\/wordpress\/?p=10410\">Read More &raquo;<\/a><\/span><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[40],"tags":[],"class_list":["post-10410","post","type-post","status-publish","format-standard","hentry","category-language"],"_links":{"self":[{"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/10410","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=10410"}],"version-history":[{"count":5,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/10410\/revisions"}],"predecessor-version":[{"id":10415,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/10410\/revisions\/10415"}],"wp:attachment":[{"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=10410"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=10410"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.skyer9.pe.kr\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=10410"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}