<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

        • vue,vant,使用過程中 Swipe 輪播自定義大小遇到的坑

          2020-4-17    前端達人

          今天講一下使用vant Swipe 輪播控件過程中遇到的問題

          主要是使用swiper自定義的大小的時候,寬度適應不同分辨率的移動設備

          適應寬度的同時還需控件的正常使用


          先看一下需要實現(xiàn)的功能,

          微信截圖_20200417142351.png

          微信截圖_20200417142429.png

          一個簡單的輪播圖,但是每個輪播的寬度需要低于100%,使第二個輪播的van-swipe-item可以展示到第一個位置一部分



          這時我們再去vant的文檔查看一下控件

          微信截圖_20200417142821.png


          剛好有一個自定義控件大小的可以使用,完美解決了我們的問題


          當我們使用控件之后


           <van-swipe :loop="false"  @change="onChange" :width="350">
                  <van-swipe-item v-bind:id="item0"><div class="swipe0">
                      <div class="contion">
          
                          <p class="title">家中有事,申請請假一天</p>
                          <p class="title1"><span class="rice"></span>部門經理核審中</p>
                          <p class="time">03.8 &nbsp;&nbsp;&nbsp; 14.25</p>
                          <p class="type">放假申請</p>
                      </div>
                      <img src="../../assets/images/index/xx/fangjia.png">
          
                  </div></van-swipe-item>
                  <van-swipe-item ><div class="swipe1"></div></van-swipe-item>
                  <van-swipe-item ><div class="swipe2"></div></van-swipe-item>
                  <template #indicator>
                      <div class="custom-indicator">
                          {{ current + 1 }}/3
                      </div>
                  </template>
              </van-swipe>



          發(fā)現(xiàn)功能可以使用,但是再 iPhone8/7 plus  以及iPhone5/se 等分辨率下出現(xiàn)了寬度固定而不適應的情況,

          微信截圖_20200417143329.png

          微信截圖_20200417143349.png


          簡單來說,我們把van-swipe-item寬度控制在了80% 第二個van-swipe-item自然可以展示出來一部分

          但是當滑到第二頁的時候 由于第一頁的寬度還是80% 所以就出現(xiàn)了這樣的情況,所以我打算采用

          監(jiān)聽 change 事件

          動態(tài)的改變 滑動到第幾頁的時候 把當頁的寬度變?yōu)?0% 其他頁保持不變,


          于是

           <van-swipe :loop="false"  @change="onChange" >
                  <van-swipe-item v-bind:id="item0"><div class="swipe0">
                      <div class="contion">
          
                          <p class="title">家中有事,申請請假一天</p>
                          <p class="title1"><span class="rice"></span>部門經理核審中</p>
                          <p class="time">03.8 &nbsp;&nbsp;&nbsp; 14.25</p>
                          <p class="type">放假申請</p>
                      </div>
                      <img src="../../assets/images/index/xx/fangjia.png">
          
                  </div></van-swipe-item>
                  <van-swipe-item v-bind:id="item1"><div class="swipe1"></div></van-swipe-item>
                  <van-swipe-item v-bind:id="item2"><div class="swipe2"></div></van-swipe-item>
                  <template #indicator>
                      <div class="custom-indicator">
                          {{ current + 1 }}/3
                      </div>
                  </template>
              </van-swipe>





          首先 我們?yōu)槊總€swipe-item添加id



           data(){
                      return {
                          android: true,
                          ios: true,
                          iphoneX: true,
                          current: 0,
                          item0:'item0',
                          item1:'item1',
                          item2:'item2',
                      }
                  },
                  mounted(){
          
                  },
                  methods: {
                      onChange(index){
                          console.log('當前 Swipe 索引:' + index);
                          if(index==1){
                              var div =document.getElementById("item0").style.setProperty('width', '10rem', 'important');
                              var div1 =document.getElementById("item1").style.setProperty('width', '9.3333333rem', 'important');
                              var div2 =document.getElementById("item2").style.setProperty('width', '9.3333333rem', 'important');
                          } else  if(index==2){
                              var div1 =document.getElementById("item1").style.setProperty('width', '10rem', 'important');
                              var div0 =document.getElementById("item0").style.setProperty('width', '10rem', 'important');
                              var div2 =document.getElementById("item2").style.setProperty('width', '9.3333333rem', 'important');
                          } else  if(index==0){
                              var div =document.getElementById("item2");
                              var div0 =document.getElementById("item0").style.setProperty('width', '9.3333333rem', 'important');
                              var div1 =document.getElementById("item1").style.setProperty('width', '9.3333333rem', 'important');
                          }
                      },



          此外,監(jiān)聽滑動事件,根據(jù)滑動到第幾頁 更改當前頁面的寬度,


          這樣就解決了




          Swipe自定義寬度下,同時適應不同分辨率的情況


          蘭蘭設計:前端達人





          日歷

          鏈接

          個人資料

          藍藍設計的小編 http://www.sdgs6788.com

          存檔

          少妇内射兰兰久久| 久久99精品国产| 久久久这里只有精品加勒比| 亚洲精品WWW久久久久久| 亚洲精品国产自在久久| 国内精品久久久久影院日本 | 午夜精品久久久久成人| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 囯产精品久久久久久久久蜜桃| 久久亚洲精品无码aⅴ大香 | 久久久久国产精品熟女影院| 26uuu久久五月天| 中文字幕无码免费久久| 97久久精品无码一区二区| 国产一区二区精品久久岳| 亚洲综合伊人久久综合| 国产精品热久久毛片| 久久久久久久久无码精品亚洲日韩 | 99国内精品久久久久久久| 国产精品成人久久久| 久久99精品免费一区二区| 国产亚洲精品自在久久| 久久综合亚洲色HEZYO社区 | 一级做a爰片久久毛片人呢| 精品多毛少妇人妻AV免费久久 | 99久久免费国产精品热| 少妇人妻综合久久中文字幕| 久久精品国产精品亚洲下载| 久久精品国内一区二区三区 | 久久久久国产亚洲AV麻豆| 国产亚洲精品美女久久久| 久久久久亚洲AV无码网站| 伊人久久综合无码成人网 | 久久久九九有精品国产| 久久精品国产亚洲av日韩| 久久影院综合精品| 乱亲女H秽乱长久久久| 成人资源影音先锋久久资源网| 久久国产欧美日韩精品| 蜜臀av性久久久久蜜臀aⅴ| 久久―日本道色综合久久|