• <noscript id="ggggg"><dd id="ggggg"></dd></noscript>
    <small id="ggggg"></small> <sup id="ggggg"></sup>
    <noscript id="ggggg"><dd id="ggggg"></dd></noscript>
    <tfoot id="ggggg"></tfoot>
  • <nav id="ggggg"><cite id="ggggg"></cite></nav>
    <nav id="ggggg"></nav>
    成人黃色A片免费看三更小说,精品人妻av区波多野结衣,亚洲第一极品精品无码,欧美综合区自拍亚洲综合,久久99青青精品免费观看,中文字幕在线中字日韩 ,亚洲国产精品18久久久久久,黄色在线免费观看

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

    2020-3-24    前端達(dá)人

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

    相關(guān)知識點(diǎn)

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

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

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

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

    效果圖

    實(shí)現(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 請檢查這里是否屬于同一點(diǎn)。 -->
     <!-- 懸浮的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: {
     // 實(shí)現(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";
      //阻止頁面的滑動默認(rèn)事件;如果碰到滑動問題,1.2 請注意是否獲取到 touchmove
      document.addEventListener("touchmove",function(){
       event.preventDefault();
      },false);
     }
     },
    //鼠標(biāo)釋放時候的函數(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>

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

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



    再加一點(diǎn)

    css之display:inline-block布局

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

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

    圖一:1.png

    圖二:

    2.png

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

     

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

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

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

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

    圖二:4.png

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

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

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

    圖四:

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

     

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

    a.上面可以看到用了display:inline-block后,存在間隙問題,間隙為4像素,這個問題產(chǎn)生的原因是換行引起的,因?yàn)槲覀儗憳?biāo)簽時通常會在標(biāo)簽結(jié)束符后順手打個回車,而回車會產(chǎn)生回車符,回車符相當(dāng)于空白符,通常情況下,多個連續(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的布局方式和浮動的布局方式,究竟使用哪個,我覺得應(yīng)該根據(jù)實(shí)際情況來決定的:
    a.對于橫向排列東西來說,我更傾向與使用inline-block來布局,因?yàn)檫@樣清晰,也不用再像浮動那樣清除浮動,害怕布局混亂等等。
    b.對于浮動布局就用于需要文字環(huán)繞的時候,畢竟這才是浮動真正的用武之地,水平排列的是就交給inline-block了。



    日歷

    鏈接

    個人資料

    存檔

    主站蜘蛛池模板: 丁香六月婷婷久久综合| 亚洲一道一本快点视频| 首页 图区 国产 亚洲 欧美| 亚洲国产精品高清第一页 | 亚洲AV片毛片成人观看| 蜜桃传媒网久热精品小视频在线| 五月天婷婷社区| av一区二区无码在线| 欧美自慰一级看片免费| 庄浪县| 亚洲小视频在线观看| 2021久久精品国产99国产| WWW夜片内射视频在观看视频| 国产亚洲午夜高清国产拍精品不卡 | 国产性天天综合网| 亚洲一级无毛片无码在线免费视频| 久久久人人人婷婷色东京热| 性色AV一区二区三区咪爱四虎| 国产成人喷潮在线观看| 尤物视频在线观看| 精品国产a∨无码一区二区三区| 岛国毛片一级一级特级毛片| 丰满人妻熟妇乱又伦精品视频三| 国产对白熟女受不了了| 国产亚洲精品自在线亚洲情侣| 大JI巴好深好爽又大又粗视频| 东城区| 国产91精品露脸国语对白| 午夜福利在线观看6080| 午夜免费国产体验区免费的| 人妻丰满av无码中文字幕| 青草娱乐极品免费视频| 制服丝袜人妻中出第一页| 又黄又无遮挡AAAAA毛片| 日韩在线网址| 天天躁日日躁狠狠躁中文字幕| 尤物成AV人片在线观看| 日本福利视频免费久久久| 国产福利在线观看永久视频| 内乡县| 国产精品吹潮在线观看中文 |