react 拖拽

最近做一個功能,一個點擊按鈕,需要支持拖拽。完成后謝在這里做一下筆記。

export default class Record extends Component {
  constructor(props) {
    super(props);
    // 限制最大寬高翰苫,不讓滑塊出去
    this.dragLimit = {
      maxW: null,
      maxH: null,
    };
    this.timer = null;
  }
  // 認購記錄拖拽
  recordDrag = (e) => {
    if (this.timer) {
      clearTimeout(this.timer);
      this.timer = null;
    }
    this.timer = setTimeout(() => {
      // 執(zhí)行點擊事件
      window.location.hash = `#${Routers.Record}`;
    }, 500);
    const ev = e || window.event;
    const touch = ev.targetTouches[0];
    const bragBox = document.querySelector('#apply-record');
    const containerBox = document.querySelector('#cal-wrap');

    if (!bragBox || !containerBox) {
      return;
    }

    if (this.dragLimit.maxW === null || this.dragLimit.maxH === null) {
      this.dragLimit = {
        maxW: containerBox.clientWidth - bragBox.offsetWidth,
        maxH: containerBox.clientHeight - bragBox.offsetHeight,
      };
    }

    // 手指觸摸開始,記錄盒子的初始位置
    const oL = touch.clientX - bragBox.offsetLeft;
    const oT = touch.clientY - bragBox.offsetTop;

    // 觸摸中的这橙,位置記錄
    bragBox.addEventListener('touchmove', (e1) => {
      if (this.timer) {
        clearTimeout(this.timer);
        this.timer = null;
      }
      const ev1 = e1 || window.event;
      const touch1 = ev1.targetTouches[0];
      let oLeft = touch1.clientX - oL;
      let oTop = touch1.clientY - oT;
      if (oLeft < 0) {
        oLeft = 0;
      } else if (oLeft >= this.dragLimit.maxW) {
        oLeft = this.dragLimit.maxW;
      }
      if (oTop < 0) {
        oTop = 0;
      } else if (oTop >= this.dragLimit.maxH) {
        oTop = this.dragLimit.maxH;
      }
      bragBox.style.left = `${oLeft}px`;
      bragBox.style.top = `${oTop}px`;
    });

    // 觸摸結(jié)束時的處理
    bragBox.addEventListener('touchend', () => {
      document.removeEventListener('touchmove', (evt) => {
        // 阻止默認事件
        evt.preventDefault();
      });
    });
  }

  render() {
    return (
      <div styleName="wrap" id="cal-wrap">
        ...
        <div id="apply-record" styleName="apply-record" onTouchStart={this.recordDrag} >
          {/* <span>認購記錄</span> */}
        </div>
        ...
      </div>
    );
  }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末奏窑,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子屈扎,更是在濱河造成了極大的恐慌埃唯,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,718評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鹰晨,死亡現(xiàn)場離奇詭異墨叛,居然都是意外死亡,警方通過查閱死者的電腦和手機模蜡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評論 3 385
  • 文/潘曉璐 我一進店門漠趁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人忍疾,你說我怎么就攤上這事闯传。” “怎么了卤妒?”我有些...
    開封第一講書人閱讀 158,207評論 0 348
  • 文/不壞的土叔 我叫張陵丸边,是天一觀的道長叠必。 經(jīng)常有香客問我,道長妹窖,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,755評論 1 284
  • 正文 為了忘掉前任收叶,我火速辦了婚禮骄呼,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘判没。我一直安慰自己蜓萄,他們只是感情好,可當我...
    茶點故事閱讀 65,862評論 6 386
  • 文/花漫 我一把揭開白布澄峰。 她就那樣靜靜地躺著嫉沽,像睡著了一般。 火紅的嫁衣襯著肌膚如雪俏竞。 梳的紋絲不亂的頭發(fā)上绸硕,一...
    開封第一講書人閱讀 50,050評論 1 291
  • 那天,我揣著相機與錄音魂毁,去河邊找鬼玻佩。 笑死,一個胖子當著我的面吹牛席楚,可吹牛的內(nèi)容都是我干的咬崔。 我是一名探鬼主播,決...
    沈念sama閱讀 39,136評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼烦秩,長吁一口氣:“原來是場噩夢啊……” “哼垮斯!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起只祠,我...
    開封第一講書人閱讀 37,882評論 0 268
  • 序言:老撾萬榮一對情侶失蹤兜蠕,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后铆农,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體牺氨,經(jīng)...
    沈念sama閱讀 44,330評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,651評論 2 327
  • 正文 我和宋清朗相戀三年墩剖,在試婚紗的時候發(fā)現(xiàn)自己被綠了猴凹。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,789評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡岭皂,死狀恐怖郊霎,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情爷绘,我是刑警寧澤书劝,帶...
    沈念sama閱讀 34,477評論 4 333
  • 正文 年R本政府宣布进倍,位于F島的核電站,受9級特大地震影響购对,放射性物質(zhì)發(fā)生泄漏猾昆。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,135評論 3 317
  • 文/蒙蒙 一骡苞、第九天 我趴在偏房一處隱蔽的房頂上張望垂蜗。 院中可真熱鬧,春花似錦解幽、人聲如沸贴见。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽片部。三九已至,卻和暖如春霜定,著一層夾襖步出監(jiān)牢的瞬間档悠,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評論 1 267
  • 我被黑心中介騙來泰國打工然爆, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留站粟,地道東北人。 一個月前我還...
    沈念sama閱讀 46,598評論 2 362
  • 正文 我出身青樓曾雕,卻偏偏與公主長得像奴烙,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子剖张,可洞房花燭夜當晚...
    茶點故事閱讀 43,697評論 2 351

推薦閱讀更多精彩內(nèi)容

  • 這篇文章基本骨架來自:文件點擊上傳和拖拽上傳 今天我們要解決的問題就是頁面上我們上傳了多個文件切诀,我們需要怎么實現(xiàn)移...
    CondorHero閱讀 6,525評論 2 2
  • 冥千洛閱讀 84評論 0 0
  • 活在當下這太平盛世,大部分人工作稱心如意搔弄,生活富足安康幅虑,家庭和諧美滿……而且很有可能未來的幾十年會是人類歷史上最美...
    厚德載物_b730閱讀 348評論 0 5
  • 這是我剛上大學的第一年,說實話顾犹,跟我之前幻想的還真的是大相徑庭倒庵,與傳統(tǒng)偶像劇不同,我所幻想的它也是簡簡單單炫刷,平平淡...
    春風十里xxl閱讀 202評論 0 0