国产69囗曝吞精在线视频,肥臀浪妇太爽了快点再快点,亚洲欧洲成人a∨在线观看,狠狠色丁香久久综合 ,国精一二二产品无人区免费应用,亚洲精品久久久久中文字幕,四虎一区二区成人免费影院网址 ,无码三级中文字幕在线观看

      vue實現(xiàn)移動端懸浮窗效果

      2020-3-24    前端達人

      本文講述,在使用VUE的移動端實現(xiàn)類似于iPhone的懸浮窗的效果。

      相關(guān)知識點

      touchstart 當在屏幕上按下手指時觸發(fā)

      touchmove 當在屏幕上移動手指時觸發(fā)

      touchend 當在屏幕上抬起手指時觸發(fā)
      mousedown mousemove mouseup對應的是PC端的事件

      touchcancel 當一些更高級別的事件發(fā)生的時候(如電話接入或者彈出信息)會取消當前的touch操作,即觸發(fā)touchcancel。一般會在touchcancel時暫停游戲、存檔等操作。

      效果圖

      實現(xiàn)步驟

      1.html

      總結(jié)了一下評論,好像發(fā)現(xiàn)大家都碰到了滑動的問題。就在這里提醒一下吧。可將該懸浮 DIV 同你的 scroller web 同級。 —- (log: 2018-08-21)

      html結(jié)構(gòu): <template> <div>你的web頁面</div> <div>懸浮DIV</div> </template>

      <template>
       <div id="webId">
       ...
       <div>你的web頁面</div>
       <!-- 如果碰到滑動問題,1.1 請檢查這里是否屬于同一點。 -->
       <!-- 懸浮的HTML -->
       <div v-if="!isShow" class="xuanfu" id="moveDiv"
        @mousedown="down" @touchstart="down"
        @mousemove="move" @touchmove="move"
        @mouseup="end" @touchend="end"
       >
        <div class="yuanqiu">
        {{pageInfo.totalPage}}
        </div>
       </div>
       ...
       </div>
      </template>

      2.JS

      <script>
      data() {
       return {
       flags: false,
       position: { x: 0, y: 0 },
       nx: '', ny: '', dx: '', dy: '', xPum: '', yPum: '',
       }
      }
      
      methods: {
       // 實現(xiàn)移動端拖拽
       down(){
       this.flags = true;
       var touch;
       if(event.touches){
        touch = event.touches[0];
       }else {
        touch = event;
       }
       this.position.x = touch.clientX;
       this.position.y = touch.clientY;
       this.dx = moveDiv.offsetLeft;
       this.dy = moveDiv.offsetTop;
       },
       move(){
       if(this.flags){
        var touch ;
        if(event.touches){
         touch = event.touches[0];
        }else {
         touch = event;
        }
        this.nx = touch.clientX - this.position.x;
        this.ny = touch.clientY - this.position.y;
        this.xPum = this.dx+this.nx;
        this.yPum = this.dy+this.ny;
        moveDiv.style.left = this.xPum+"px";
        moveDiv.style.top = this.yPum +"px";
        //阻止頁面的滑動默認事件;如果碰到滑動問題,1.2 請注意是否獲取到 touchmove
        document.addEventListener("touchmove",function(){
         event.preventDefault();
        },false);
       }
       },
      //鼠標釋放時候的函數(shù)
       end(){
       this.flags = false;
       },
      }
      </script>

      3.CSS

      <style>
       .xuanfu {
       height: 4.5rem;
       width: 4.5rem;
       /* 如果碰到滑動問題,1.3 請檢查 z-index。z-index需比web大一級*/
       z-index: 999;
       position: fixed;
       top: 4.2rem;
       right: 3.2rem;
       border-radius: 0.8rem;
       background-color: rgba(0, 0, 0, 0.55);
       }
       .yuanqiu {
       height: 2.7rem;
       width: 2.7rem;
       border: 0.3rem solid rgba(140, 136, 136, 0.5);
       margin: 0.65rem auto;
       color: #000000;
       font-size: 1.6rem;
       line-height: 2.7rem;
       text-align: center;
       border-radius: 100%;
       background-color: #ffffff;
       }
      </style>

      實現(xiàn)好JS邏輯,基本上,問題不大。

      本文鏈接 http://www.luyixian.cn/javascript_show_166242.aspx



      再加一點

      css之display:inline-block布局

      1.解釋一下display的幾個常用的屬性值,inline , block, inline-block

      • inline(行內(nèi)元素):
        1. 使元素變成行內(nèi)元素,擁有行內(nèi)元素的特性,即可以與其他行內(nèi)元素共享一行,不會獨占一行. 
        2. 不能更改元素的height,width的值,大小由內(nèi)容撐開. 
        3. 可以使用padding上下左右都有效,margin只有l(wèi)eft和right產(chǎn)生邊距效果,但是top和bottom就不行.
      • block(塊級元素):
        1. 使元素變成塊級元素,獨占一行,在不設(shè)置自己的寬度的情況下,塊級元素會默認填滿父級元素的寬度. 
        2. 能夠改變元素的height,width的值. 
        3. 可以設(shè)置padding,margin的各個屬性值,top,left,bottom,right都能夠產(chǎn)生邊距效果.
      •  inline-block(融合行內(nèi)于塊級):
        1. 結(jié)合了inline與block的一些特點,結(jié)合了上述inline的第1個特點和block的第2,3個特點.
        2. 用通俗的話講,就是不獨占一行的塊級元素。如圖:

      圖一:1.png

      圖二:

      2.png

      兩個圖可以看出,display:inline-block后塊級元素能夠在同一行顯示,有人這說不就像浮動一樣嗎。沒錯,display:inline-block的效果幾乎和浮動一樣,但也有不同,接下來講一下inline-block和浮動的比較。

       

      2.inline-block布局 vs 浮動布局

          a.不同之處:對元素設(shè)置display:inline-block ,元素不會脫離文本流,而float就會使得元素脫離文本流,且還有父元素高度坍塌的效果

          b.相同之處:能在某程度上達到一樣的效果

      我們先來看看這兩種布局:
      圖一:display:inline-block3.png

      圖二:4.png

      對兩個孩子使用float:left,我在上一篇浮動布局講過,這是父元素會高度坍塌,所以要閉合浮動,對box使用overflow:hidden,效果如下:

      >>乍一看兩個都能做到幾乎相同的效果,(仔細看看display:inline-block中有間隙問題,這個留到下面再講)

      c.浮動布局不太好的地方:參差不齊的現(xiàn)象,我們看一個效果:
      圖三:

      圖四:

      >>從圖3,4可以看出浮動的局限性在于,若要元素排滿一行,換行后還要整齊排列,就要子元素的高度一致才行,不然就會出現(xiàn)圖三的效果,而inline-block就不會。

       

      3.inline-block存在的小問題:

      a.上面可以看到用了display:inline-block后,存在間隙問題,間隙為4像素,這個問題產(chǎn)生的原因是換行引起的,因為我們寫標簽時通常會在標簽結(jié)束符后順手打個回車,而回車會產(chǎn)生回車符,回車符相當于空白符,通常情況下,多個連續(xù)的空白符會合并成一個空白符,而產(chǎn)生“空白間隙”的真正原因就是這個讓我們并不怎么注意的空白符。

       

      b.去除空隙的方法:
      1.對父元素添加,{font-size:0},即將字體大小設(shè)為0,那么那個空白符也變成0px,從而消除空隙
      現(xiàn)在這種方法已經(jīng)可以兼容各種瀏覽器,以前chrome瀏覽器是不兼容的
      圖一:

       

      c.瀏覽器兼容性:ie6/7是不兼容 display:inline-block的所以要額外處理一下:
      在ie6/7下:
      對于行內(nèi)元素直接使用{dislplay:inline-block;}5.png
      對于塊級元素:需添加{display:inline;zoom:1;}

       6.png

      4.總結(jié):

      display:inline-block的布局方式和浮動的布局方式,究竟使用哪個,我覺得應該根據(jù)實際情況來決定的:
      a.對于橫向排列東西來說,我更傾向與使用inline-block來布局,因為這樣清晰,也不用再像浮動那樣清除浮動,害怕布局混亂等等。
      b.對于浮動布局就用于需要文字環(huán)繞的時候,畢竟這才是浮動真正的用武之地,水平排列的是就交給inline-block了。



      日歷

      鏈接

      個人資料

      藍藍設(shè)計的小編 http://m.izc.net.cn

      存檔

      主站蜘蛛池模板: 狠狠色婷婷丁香综合久久| 九九九九国产| 久久强奷乱码老熟女网站| 国产精品爆乳奶水无码视频| japanese24hdxxxx日韩| 亚洲国产欧美不卡在线观看| 亚洲精品拍拍央视网出文| 日本女优一区| xxxx国产精品| 国产乱理伦片在线观看| 欧美丰满熟妇xxxx性多毛| 久久久久久伊人| 福利网站在线| 亚洲人成电影在线观看影院 | 亚洲一区在线日韩在线深爱| 在线黄色网| 午夜不卡影院| 亚洲人成无码区在线观看| 国产又爽又黄又舒服又刺激视频| 97在线观看免费高清| 日韩偷拍一区| 久久丫精品系列| 亚洲 欧美 中文 日韩 综合| 在线观看你懂得| 大奶骚| 亚洲精品三区二区一区一| 日本阿v片在线播放免费| av在线播放网址| 特级少妇| 免费AV手机在线观看片| 亚洲国产良家在线观看| 亚洲色一色噜一噜噜噜| 日韩欧美一区二区三区在线观看| 日韩国产成人精品视频| 国产乱人伦偷精品视频不卡| 久久婷婷五月综合鬼色| 三级黄网站| 蜜臀网在线| 亚洲乱码日产精品bd在线观看| 亚洲国产精品嫩草影院久久| 国产一区二区视频在线播放|