{"id":23854882,"url":"https://github.com/junqiuzhang/easy-drag","last_synced_at":"2025-09-08T02:31:00.036Z","repository":{"id":46089015,"uuid":"416717052","full_name":"junqiuzhang/easy-drag","owner":"junqiuzhang","description":"easy to realize drag and drop effect","archived":false,"fork":false,"pushed_at":"2022-05-13T14:15:35.000Z","size":48,"stargazers_count":36,"open_issues_count":1,"forks_count":11,"subscribers_count":2,"default_branch":"master","last_synced_at":"2024-12-13T08:12:54.849Z","etag":null,"topics":["css3","drag-and-drop","draggable","javascript"],"latest_commit_sha":null,"homepage":"","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/junqiuzhang.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2021-10-13T11:41:07.000Z","updated_at":"2024-06-13T01:15:42.000Z","dependencies_parsed_at":"2022-09-26T18:30:30.633Z","dependency_job_id":null,"html_url":"https://github.com/junqiuzhang/easy-drag","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/junqiuzhang%2Feasy-drag","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/junqiuzhang%2Feasy-drag/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/junqiuzhang%2Feasy-drag/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/junqiuzhang%2Feasy-drag/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/junqiuzhang","download_url":"https://codeload.github.com/junqiuzhang/easy-drag/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":232272346,"owners_count":18497826,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["css3","drag-and-drop","draggable","javascript"],"created_at":"2025-01-03T00:18:22.008Z","updated_at":"2025-01-03T00:18:22.541Z","avatar_url":"https://github.com/junqiuzhang.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# easy-drag\n\n[中文文档](https://github.com/junqiuzhang/easy-drag/blob/master/README_zh-CN.md)\n\nEasy to realize drag effect\n\n## Principle\n\nListen to `mousedown`, `mousemove`, and `mouseup` events, and set the element's transform property to drag and drop according to the mouse position\n\n## Feature\n\n1. Use JavaScript implementation, support any framework\n2. Use `transform` property implementation that supports elements in any positioning mode\n3. Lightweight, only 2KB\n4. Performance, hardware acceleration for a silky drag experience\n5. Supports PC and mobile terminals\n\n## Install\n\n```\n# Yarn\nyarn add easy-drag\n\n# NPM\nnpm install --save easy-drag\n\n```\n\n## Usage\n\n```ts\nimport enableDrag from \"easy-drag\";\nconst disableDrag = enableDrag(document.querySelector(\".draggable\"));\nif (\"want to disable drag\") {\n  disableDrag();\n}\n```\n\nOr\n\n```ts\nimport enableDrag from \"easy-drag\";\nconst disableDrag = enableDrag(document.querySelector(\".draggable\"), {\n  outerElement: document.body,\n  innerElement: document.querySelector(\".drag-icon\"),\n  onDragStart: () =\u003e {},\n  onDrag: () =\u003e {},\n  onDragEnd: () =\u003e {},\n});\nif (\"want to disable drag\") {\n  disableDrag();\n}\n```\n\nDescription:\n\n- outerElement: drag range element, default document.body\n- innerElement: drag icon element, application scenario: Pop-ups need to be draggable, but only the title area can be dragged\n- onDragStart: callback on drag start, parameter v is element drag translate vector (relative to initial position)\n- onDrag: callback in dragging, parameter v is element drag translate vector (relative to initial position)\n- onDragEnd: callback on drag end, parameter v is element drag translate vector (relative to initial position)\n\n### Interface\n\n```ts\nimport { TVector } from \"./utils\";\ninterface IOptions {\n  /** element that control drag range */\n  outerElement?: HTMLElement;\n  /** element that to drag */\n  innerElement?: HTMLElement;\n  /** callback on drag start */\n  onDragStart?: (v: TVector) =\u003e void;\n  /** callback in dragging */\n  onDrag?: (v: TVector) =\u003e void;\n  /** callback on drag end */\n  onDragEnd?: (v: TVector) =\u003e void;\n}\n/**\n * use transform easy to realize drag effect\n */\ndeclare const enableDrag: (\n  element: HTMLElement,\n  options?: IOptions | undefined\n) =\u003e () =\u003e void;\nexport default enableDrag;\n```\n\n## License\n\nMIT\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjunqiuzhang%2Feasy-drag","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fjunqiuzhang%2Feasy-drag","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjunqiuzhang%2Feasy-drag/lists"}