报告,我想让我的DOM元素可以拖动到任意坐标!

思路

  1. 点击 -> 记录鼠标点击的位置,距离目标元素的位置(left, top) -> 存放到React-redux;
  2. 拖动
  3. 放置 -> 取React-redux中记录的位置;

实现

一、子组件(被拖动)

import image from "@/assets/20200921.jpg";
import "./index.scss";
import { connect } from "react-redux";
function Child(props) {
    const dragStart = (event) => {
        let x = event.clientX - event.target.offsetLeft;
        let y = event.clientY - event.target.offsetTop;
        props.setMousePosition({ x, y });
        event.dataTransfer.setData("Text", event.target.id);
    };
    return (
        <>
            <article id="drag1" draggable="true" onDragStart={dragStart}>
                <section className="section" onMouseEnter={handleHover}>
                    <img className="image" src={image} alt="" />
                    <div className="card_content">
                        <span>{title}</span>
                    </div>
                </section>
            </article>
        </>
    );
}

const mapStateToProps = (state) => {
    return {
        state,
    };
};
const mapDispatchToProps = (dispatch) => {
    return {
        setMousePosition: (mousePosition) => {
            dispatch({ type: "SET_MOUSE_POSITION", mousePosition });
        },
    };
};

export default connect(mapStateToProps, mapDispatchToProps)(Child);

二、父组件

import "./styles/App.css";
//router
import Router from "./router";
// react-redux
import { connect } from "react-redux";
//component
import Child from "./Child";

function App(props) {
    const allowDrop = (event) => {
        event.preventDefault();
    };
    const drop = (event) => {
        event.preventDefault();
        let data = event.dataTransfer.getData("Text");
        let leftPx = event.clientX - props.state.mousePosition.x + "px";
        let topPx = event.clientY - props.state.mousePosition.y + "px";
        document.getElementById(data).style.left = leftPx;
        document.getElementById(data).style.top = topPx;
    };
    return (
        <div className="App" onDragOver={allowDrop} onDrop={drop}>
            <Child />
        </div>
    );
}

const mapStateToProps = (state) => {
    return {
        state,
    };
};

export default connect(mapStateToProps)(App);

三、React-redux

import { createStore } from "redux";

let initState = {
    count: 0,
    mousePosition: { x: 0, y: 0 },
};

function rootReducer(state = initState, action) {
    switch (action.type) {
        case "SET_MOUSE_POSITION":
            return {
                ...state,
                mousePosition: {
                    x: action.mousePosition.x,
                    y: action.mousePosition.y,
                },
            };
        default:
            return state;
    }
}

let store = createStore(
    rootReducer,
    window.__REDUX_DEVTOOLS_EXTENSION__ && window.__REDUX_DEVTOOLS_EXTENSION__()
);

export default store;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值