React影像彈出框Modal【可配置縮放、拖拽无蜂、旋轉(zhuǎn)等】

序:

整理了一下開發(fā)的一個React影像組件

由于一些(亂七八糟)的需求伺糠,導(dǎo)致之前的組件影像代碼冗余,不可維護(hù)

看不下去了斥季,是時候出來拯救世界了

于是我上場了

我做的事训桶,就是將各類功能函數(shù)抽離累驮,同時代碼盡可能的少

這個組件的主要功能有:拖拽、水印舵揭、縮放谤专、切換、旋轉(zhuǎn)(更新中)

以及一些小的功能點(diǎn)比如:鍵盤左右切換午绳、移動時增加透明度等一些細(xì)節(jié)的優(yōu)化

不多bb了吧置侍,直接上demo, 自己上來動 傳送門

下面我會寫一下一些功能的實現(xiàn)

<hr />

拖拽:

鼠標(biāo)移動的時候改變modal的位置就可以了

并且要設(shè)置一下透明度

let nx = e.clientX;
    let ny = e.clientY;
    // 計算移動后的左偏移量和頂部的偏移量
    let nl = nx - (x - l);
    let nt = ny - (y - t);
  
    dv.style.left = nl + 'px';
    dv.style.top = nt + 'px';

    // 設(shè)置移動時透明
    dv.querySelector('.image-content').style.opacity = .3;

關(guān)于這個移動,有個地方要注意

比如我們頁面上有兩個modal拦焚,要保證最后點(diǎn)擊的modal要覆蓋之前點(diǎn)擊的modal

也就是zIndex要控制好蜡坊,這里用localStorage來保存這個最大的zIndex

imageModalMaxzIndex = localStorage.getItem('imageModalMaxzIndex');
    if (dv.style.zIndex != imageModalMaxzIndex) {
      dv.style.zIndex = +imageModalMaxzIndex + 1;
      localStorage.setItem('imageModalMaxzIndex', dv.style.zIndex);
    }

<hr />

水印

前端實現(xiàn)水印,避免私密圖片泄露

其實水印有好幾種解決方案 dom赎败、canvas秕衙、svg等

這里用canvas實現(xiàn)

思路就是將文本用canvas生成圖片,然后將該圖片作為背景repeat

    const canvas = document.createElement('canvas');
    canvas.setAttribute('width', width);
    canvas.setAttribute('height', height);
    canvas.setAttribute('opacity', opacity);
    const ctx = canvas.getContext('2d');
  
    ctx.textAlign = textAlign;
    ctx.textBaseline = textBaseline;
    ctx.font = font;
    ctx.fillStyle = fillStyle;
    ctx.rotate(Math.PI / 180 * 30);
    ctx.fillText(fillText, 80, 10);
        
    var base64Url = canvas.toDataURL();
    const watermarkDiv = document.createElement('div');
    watermarkDiv.setAttribute('style', `
          position:absolute;
          top:0;
          left:0;
          width:100%;
          height:${scrollHeight || '100%'};
          z-index:1000;
          pointer-events:none;
          background-repeat:repeat;
          background-image:url('${base64Url}')
    `);

這里有一篇文章總結(jié)了幾種前端水印的方案僵刮,推薦給大家 文章

<hr />

縮放

縮放的話据忘,監(jiān)聽鼠標(biāo)滾動事件

向上滾動放大,向下滾動縮小這樣

這里要注意控制最小縮放值搞糕,不然會比原子還小若河,很危險的

還要注意的是圖片在邊界的縮放,會突然迷失在宇宙中(移除屏幕寞宫,這是可能的)

這里要做的處理是判斷左邊界跟圖片的寬度

// 不讓modal由于縮小消失在視野中
  if (modalLeft + calcWidth < 50) {
    return;
  }

<hr />

切換

切換其實就是改變imageModal的src

  prev() {
    const { currentImageIndex } = this.state;
    if (currentImageIndex > 0) {
      this.setState({ currentImageIndex: currentImageIndex - 1 });
    }
  }

  next() {
    const { currentImageIndex, imageList } = this.state;
    if (currentImageIndex < imageList.length - 1) {
      this.setState({ currentImageIndex: currentImageIndex + 1 });
    }
  }

<hr />

關(guān)于組件的使用

如果你看得起這個組件萧福,剛好你又有這中神奇的需求,需要這么個影像組件辈赋,那以下:

主要的東西就四個鲫忍,一個common文件夾,一個imageModal.js钥屈、一個Container.js悟民、一個index.css

將這四個文件拿出來,自己根據(jù)自己的需求改就行

調(diào)用方法:

<ImageModal 
  visible={modalVisible}
  src={imageList[currentImageIndex]}
  next={() => this.next()}
  prev={() => this.prev()}
  closeModal={() => this.closeImg()}
  option={{
    move: true,
    waterMarkText: '多功能圖片組件',
    rotate: true,
    zoom: true
  }}
/>

github地址

交流請加wx: c13266836563

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末篷就,一起剝皮案震驚了整個濱河市射亏,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌竭业,老刑警劉巖智润,帶你破解...
    沈念sama閱讀 221,430評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異未辆,居然都是意外死亡窟绷,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,406評論 3 398
  • 文/潘曉璐 我一進(jìn)店門咐柜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來兼蜈,“玉大人攘残,你說我怎么就攤上這事∥辏” “怎么了歼郭?”我有些...
    開封第一講書人閱讀 167,834評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長辐棒。 經(jīng)常有香客問我病曾,道長,這世上最難降的妖魔是什么涉瘾? 我笑而不...
    開封第一講書人閱讀 59,543評論 1 296
  • 正文 為了忘掉前任知态,我火速辦了婚禮,結(jié)果婚禮上立叛,老公的妹妹穿的比我還像新娘负敏。我一直安慰自己,他們只是感情好秘蛇,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,547評論 6 397
  • 文/花漫 我一把揭開白布其做。 她就那樣靜靜地躺著,像睡著了一般赁还。 火紅的嫁衣襯著肌膚如雪妖泄。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,196評論 1 308
  • 那天艘策,我揣著相機(jī)與錄音蹈胡,去河邊找鬼。 笑死朋蔫,一個胖子當(dāng)著我的面吹牛罚渐,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播驯妄,決...
    沈念sama閱讀 40,776評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼荷并,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了青扔?” 一聲冷哼從身側(cè)響起源织,我...
    開封第一講書人閱讀 39,671評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎微猖,沒想到半個月后谈息,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,221評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡励两,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,303評論 3 340
  • 正文 我和宋清朗相戀三年黎茎,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片当悔。...
    茶點(diǎn)故事閱讀 40,444評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡傅瞻,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出盲憎,到底是詐尸還是另有隱情嗅骄,我是刑警寧澤,帶...
    沈念sama閱讀 36,134評論 5 350
  • 正文 年R本政府宣布饼疙,位于F島的核電站溺森,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏窑眯。R本人自食惡果不足惜屏积,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,810評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望磅甩。 院中可真熱鬧炊林,春花似錦、人聲如沸卷要。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,285評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽僧叉。三九已至奕枝,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間瓶堕,已是汗流浹背隘道。 一陣腳步聲響...
    開封第一講書人閱讀 33,399評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留郎笆,地道東北人谭梗。 一個月前我還...
    沈念sama閱讀 48,837評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像题画,于是被迫代替她去往敵國和親默辨。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,455評論 2 359

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