整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          vue實現滑塊拖拽校驗

          義骨架,寫html和css

          html部分

          <template>
              <div class="drag-wrapper" ref="dragDiv">
                  <div class="drag_bg"></div>
                  <div class="drag_text f14">{{ confirmWords }}</div>
                  <!-- 移動的模塊 -->
                  <div ref="moveDiv"
                       @mousedown="mousedownFn($event)"
                       :class="{'handler_ok_bg': confirmSuccess}"
                       class="handler handler_bg"></div>
              </div>
          </template>
          

          css部分: 由于擔心圖片源的問題,所以寫成了base64的圖片

          <style scoped>
              .drag{
                  position: relative;
                  background-color: #e8e8e8;
                  width: 100%;
                  height: 40px;
                  line-height: 40px;
                  text-align: center;
              }
              .handler{
                  width: 40px;
                  height: 40px;
                  border: 1px solid #ccc;
                  cursor: move;
                  position: absolute;top: 0px;left: 0px;
              }
              .handler_bg{
                  background: #fff url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3hpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNS1jMDIxIDc5LjE1NTc3MiwgMjAxNC8wMS8xMy0xOTo0NDowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDo0ZDhlNWY5My05NmI0LTRlNWQtOGFjYi03ZTY4OGYyMTU2ZTYiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6NTEyNTVEMURGMkVFMTFFNEI5NDBCMjQ2M0ExMDQ1OUYiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6NTEyNTVEMUNGMkVFMTFFNEI5NDBCMjQ2M0ExMDQ1OUYiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTQgKE1hY2ludG9zaCkiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDo2MTc5NzNmZS02OTQxLTQyOTYtYTIwNi02NDI2YTNkOWU5YmUiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6NGQ4ZTVmOTMtOTZiNC00ZTVkLThhY2ItN2U2ODhmMjE1NmU2Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+YiRG4AAAALFJREFUeNpi/P//PwMlgImBQkA9A+bOnfsIiBOxKcInh+yCaCDuByoswaIOpxwjciACFegBqZ1AvBSIS5OTk/8TkmNEjwWgQiUgtQuIjwAxUF3yX3xyGIEIFLwHpKyAWB+I1xGSwxULIGf9A7mQkBwTlhBXAFLHgPgqEAcTkmNCU6AL9d8WII4HOvk3ITkWJAXWUMlOoGQHmsE45ViQ2KuBuASoYC4Wf+OUYxz6mQkgwAAN9mIrUReCXgAAAABJRU5ErkJggg==") no-repeat center;
              }
              .handler_ok_bg{
                  background: #fff url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3hpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNS1jMDIxIDc5LjE1NTc3MiwgMjAxNC8wMS8xMy0xOTo0NDowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDo0ZDhlNWY5My05NmI0LTRlNWQtOGFjYi03ZTY4OGYyMTU2ZTYiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6NDlBRDI3NjVGMkQ2MTFFNEI5NDBCMjQ2M0ExMDQ1OUYiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6NDlBRDI3NjRGMkQ2MTFFNEI5NDBCMjQ2M0ExMDQ1OUYiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTQgKE1hY2ludG9zaCkiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDphNWEzMWNhMC1hYmViLTQxNWEtYTEwZS04Y2U5NzRlN2Q4YTEiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6NGQ4ZTVmOTMtOTZiNC00ZTVkLThhY2ItN2U2ODhmMjE1NmU2Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+k+sHwwAAASZJREFUeNpi/P//PwMyKD8uZw+kUoDYEYgloMIvgHg/EM/ptHx0EFk9I8wAoEZ+IDUPiIMY8IN1QJwENOgj3ACo5gNAbMBAHLgAxA4gQ5igAnNJ0MwAVTsX7IKyY7L2UNuJAf+AmAmJ78AEDTBiwGYg5gbifCSxFCZoaBMCy4A4GOjnH0D6DpK4IxNSVIHAfSDOAeLraJrjgJp/AwPbHMhejiQnwYRmUzNQ4VQgDQqXK0ia/0I17wJiPmQNTNBEAgMlQIWiQA2vgWw7QppBekGxsAjIiEUSBNnsBDWEAY9mEFgMMgBk00E0iZtA7AHEctDQ58MRuA6wlLgGFMoMpIG1QFeGwAIxGZo8GUhIysmwQGSAZgwHaEZhICIzOaBkJkqyM0CAAQDGx279Jf50AAAAAABJRU5ErkJggg==") no-repeat center;
              }
              .drag_bg{
                  background-color: #7ac23c;
                  height: 40px;
                  width: 0px;
              }
              .drag_text{
                  position: absolute;
                  top: 0px;
                  width: 100%;text-align: center;
                  -moz-user-select: none;
                  -webkit-user-select: none;
                  user-select: none;
                  -o-user-select:none;
                  -ms-user-select:none;
              }
          </style>
          

          實現滑動拖拽校驗

          定義參數

          data() {
              return {
                  beginClientX:0,               // 距離屏幕左端距離
                  mouseMoveStata:false,         // 觸發拖動狀態  判斷
                  maxwidth:'',                  // 拖動最大寬度,依據滑塊寬度算出來的
                  confirmWords:'拖動滑塊驗證',   // 滑塊文字
                  confirmSuccess:false          // 驗證成功判斷
              }
          }
          

          1. 在mounted里面,根據滑塊寬度計算可拖動最大寬度以及監聽手指的觸摸和離開事件

          mounted() {
              // 根據滑塊寬度計算可拖動最大寬度
              this.maxwidth = this.$refs.dragDiv.clientWidth - this.$refs.moveDiv.clientWidth
              // 監聽手指的觸摸事件
              document.getElementsByTagName('html')[0].addEventListener('mousemove', this.mouseMoveFn)
              // 監聽手指離開事件
              document.getElementsByTagName('html')[0].addEventListener('mouseup', this.moseUpFn)
          }
          

          2. 編寫手指滑動的事件和手指離開的事件

          • mousemove事件

          首先判斷是否觸發拖動狀態,然后計算拖動的距離和模塊距離,實時賦值

          //驗證成功函數
          mouseMoveFn(e){
              if(this.mouseMoveStata){
                  let width = e.clientX - this.beginClientX
                  if(width > 0 && width <= this.maxwidth) {
                      document.getElementsByClassName('handler')[0].style.left = width + 'px'
                      document.getElementsByClassName('drag_bg')[0].style.width = width + 'px'
                  }else if(width > this.maxwidth) this.successFunction()
              }
          },
          
          • mouseup事件

          拖動狀態改成false,并且把滑塊移到對應的手指落下位置上

          moseUpFn(e) {
              this.mouseMoveState = !1                        // 修改狀態
              const width = e.clientX - this.beginClientX     // 計算獲取寬度
              if(width < this.maxwidth) {                     // 當寬度小于模塊的寬度時,賦值
                  document.getElementsByClassName('handler')[0].style.left = 0 + 'px'
                  document.getElementsByClassName('drag_bg')[0].style.width = 0 + 'px'
              }
          }
          

          在上面html部分的handler塊里,定義了mousedown事件(mousedownFn($event))

          需要阻止文件選中等瀏覽器默認行為,并把觸發拖動狀態這個閾值打開,記錄手指移動的距離

          mousedownFn:function (e) {
              e.preventDefault && e.preventDefault()   // 阻止文字選中等 瀏覽器默認事件
              this.mouseMoveStata = true               // 把觸發拖動狀態這個閾值打開
              this.beginClientX = e.clientX            // 記錄手指移動的距離
          },
          

          至此,功能就完成了。。

          完整的JS代碼如下

          <script>
              export default {
                  data(){
                      return {
                          beginClientX:0,           /*距離屏幕左端距離*/
                          mouseMoveStata:false,     /*觸發拖動狀態  判斷*/
                          maxwidth:'',               /*拖動最大寬度,依據滑塊寬度算出來的*/
                          confirmWords:'拖動滑塊驗證',   /*滑塊文字*/
                          confirmSuccess:false           /*驗證成功判斷*/
                      }
                  },
                  mounted(){
                      this.maxwidth = this.$refs.dragDiv.clientWidth - this.$refs.moveDiv.clientWidth
                      document.getElementsByTagName('html')[0].addEventListener('mousemove',this.mouseMoveFn)
                      document.getElementsByTagName('html')[0].addEventListener('mouseup',this.moseUpFn)
                  },
                  methods: {
                      mousedownFn:function (e) {
                          if(!this.confirmSuccess){
                              e.preventDefault && e.preventDefault()   //阻止文字選中等 瀏覽器默認事件
                              this.mouseMoveStata = true
                              this.beginClientX = e.clientX
                          }
                      },
                      //mousedoen 事件
                      successFunction(){
                          this.confirmSuccess = true
                          this.confirmWords = '驗證通過'
                          this.$emit('onValidation', true)
                          if(window.addEventListener){
                              document.getElementsByTagName('html')[0].removeEventListener('mousemove',this.mouseMoveFn)
                              document.getElementsByTagName('html')[0].removeEventListener('mouseup',this.moseUpFn)
                          }else document.getElementsByTagName('html')[0].removeEventListener('mouseup',()=>{})
                          document.getElementsByClassName('drag_text')[0].style.color = '#fff'
                          document.getElementsByClassName('handler')[0].style.left = this.maxwidth + 'px'
                          document.getElementsByClassName('drag_bg')[0].style.width = this.maxwidth + 'px'
                      },
                      //驗證成功函數
                      mouseMoveFn(e){
                          if(this.mouseMoveStata){
                              let width = e.clientX - this.beginClientX
                              if(width > 0 && width <= this.maxwidth) {
                                  document.getElementsByClassName('handler')[0].style.left = width + 'px'
                                  document.getElementsByClassName('drag_bg')[0].style.width = width + 'px'
                              }else if(width > this.maxwidth) this.successFunction()
                          }
                      },
                      //mousemove事件
                      moseUpFn(e){
                          this.mouseMoveStata = false
                          var width = e.clientX - this.beginClientX
                          if(width<this.maxwidth){
                              document.getElementsByClassName('handler')[0].style.left = 0 + 'px'
                              document.getElementsByClassName('drag_bg')[0].style.width = 0 + 'px'
                          }
                      }
                  }
              }
          </script>
          

          最后最后:

          公眾號:小何成長,佛系更文,都是自己曾經踩過的坑或者是學到的東西

          有興趣的小伙伴歡迎關注我哦,我是:何小玍。 大家一起進步鴨

          覽網頁時往往會遇到類鼠標滑過圖片時圖片會進行縮放的效果,簡單來說就是利用CSS3 中的2D轉換的縮放加上一些簡單的屬性設置實現的,img:hover+scale實現鼠標到圖片時的圖片縮放,transition添加過渡效果,使圖片的縮放更加自然,設置overflow:hidden,使圖片放大后超出部分不再顯示。

          注:div寬高與img寬高均需設置,并且img圖片需設置寬高與div盒子寬高相同。如果圖片設置寬高小于div盒子的寬高,則會出現img盒子整體放大的效果,而不是只是圖片本身的放大;若圖片設置圖片寬高大于div盒子的寬高,則會出現圖片顯示不完整的情況。具體代碼及效果如下圖所示:

          利用hover+scale+transition實現圖片放大代碼示例

          img寬高等于div寬高時的縮放效果圖

          img寬高小于div寬高時的縮放效果圖

          img寬高大于div寬高時的縮放效果圖

          僅以此作為學習筆記以及分享,如有需改進或者不妥之處,請多多指教。

          1+0.01=1.01

          1-0.01=0.99

          片畫廊組件是網站中常見的UI組件,尤其是在電商平臺的產品詳情頁上,它允許用戶通過縮略圖快速瀏覽和查看產品的多個圖片。本文介紹如何僅使用原生的js、css和html實現下面動畫呈現的圖片畫廊組件。

          功能介紹

          1. html結構中上方為主圖區域,下方為縮略圖列表,縮略圖列表的兩邊為控制水平左右滑動的箭頭導航;
          2. 鼠標移動到某個縮略圖上時,主圖區域將顯示縮略圖的大圖,并且縮略圖著紅色邊框以突出顯示;
          3. 點擊右側箭頭,縮略圖向左側滑動直到最右側的縮略圖顯示在視野中,此時右側箭頭失效;類似的,點擊左側箭頭,縮略圖向右側滑動直到最左側縮略圖出現在視野中,此時左側箭頭失效。

          HTML結構

          首先創建HTML結構,包括主圖區域和下方導航區域,需要重點交代的是id為spec-list的div元素是縮略圖列表的容器,容器的position屬性是relative,設置了固定的寬度,overflow設置為hidden,這樣其子元素超過寬度的部分將不可見,它就相當于窗戶,提供了一個矩形的的可見視野。ul裝載所有的縮略圖,它的position屬性設置為absolute,這樣就可以基于其父元素設置偏移量,它的寬度大于父元素的寬度,這樣就通過設置left屬性實現左右滑動,在父窗口范圍內的縮略圖將是可見的,這樣就實現了滑動效果。

          <div class="product-intro">
          	<div class="preview-wrap">
          		<div class="preview" id="preview">
          			<!-- 主圖顯示區域 -->
          			<div class="main-img" style="width: 460px; height: 460px;">
          				<img id="spec-img" alt="" src="./images/ai-generated-8833166_1280.webp" 
          					style="width: 100%; height: 100%; object-fit: cover;">
          			</div>
          
          			<!-- 下方導航列表 -->
          			<div class="spec-list" style="width: 452px;">
          				<!-- 左側箭頭 -->
          				<a id="spec-forward" href="javascript:;" class="arrow-prev disabled">
          					<i class="sprite-arrow-prev">
          						<svg xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" viewBox="0 0 24 24" style="scale:2;">
          							<path fill="currentColor" fill-rule="evenodd" d="m15 4l2 2l-6 6l6 6l-2 2l-8-8z"/>
          						</svg>
          					</i>
          				</a>
          				<!-- 右側箭頭 -->
          				<a id="spec-backward" href="javascript:;" class="arrow-next">
          					<i class="sprite-arrow-next">
          						<svg xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" viewBox="0 0 24 24" style="scale:2;">
          							<path fill="currentColor" fill-rule="evenodd" d="m9.005 4l8 8l-8 8L7 18l6.005-6L7 6z"/>
          						</svg>
          					</i>
          				</a>
          				<!-- 縮略圖列表可見區域 -->
          				<div id="spec-list" class="spec-items"
          					style="position: relative; width: 380px; height: 58px; overflow: hidden;">
          					<!-- 縮略圖列表 -->
          					<ul class="lh" style="position: absolute; width: 456px; height: 58px; top: 0px; left: 0px;">
          						<li class="img-hover"><img alt="" src="./images/ai-generated-8833166_1280.webp" width="54" height="54"></li>
          						<li class=""><img alt="" src="./images/owl-50267_1280.jpg" width="54" height="54"></li>
          						<li class=""><img alt="" src="./images/seal-8834240_1280.webp" width="54" height="54"></li>
          						<li class=""><img alt="" src="./images/stork-8830107_1280.webp" width="54" height="54"></li>
          						<li class=""><img alt="" src="./images/triggerfish-8832563_1280.webp" width="54" height="54"></li>
          						<li class=""><img alt="" src="./images/ai-generated-8834126_1280.webp" width="54" height="54"></li>
          					</ul>
          				</div>
          			</div>
          		</div>
          	</div>
          </div>
          

          CSS樣式

          .product-intro {
              position: relative;
              z-index: 1;
              margin-top: 10px;
              padding-bottom: 10px
          }
          
          .product-intro .preview-wrap {
              float: left;
              padding-bottom: 15px;
              position: relative;
              zoom:1;
              z-index: 7
          }
          
          .preview {
              position: relative
          }
          
          .preview .main-img {
              border: 1px solid #eee;
              margin-bottom: 20px;
              zoom: 1
          }
          
          .preview svg {
              color: #CCCCCC;
          }
          
          .preview .spec-list {
              margin-bottom: 18px;
              position: relative;
              zoom: 1
          }
          
          .preview .spec-list ul {
              margin: 0;
              transition: left 0.5s ease;
              list-style-type: none;
              padding-left: 0;
          }
          
          .preview .spec-list .arrow-next,.preview .spec-list .arrow-prev {
              display: block;
              width: 22px;
              height: 32px;
              float: left;
              position: absolute;
              cursor: pointer;
              top: 50%;
              margin-top: -16px
          }
          
          .preview .spec-list .arrow-next i,.preview .spec-list .arrow-prev i {
              display: block
          }
          
          .preview .spec-list .arrow-prev {
              left: 0
          }
          
          .preview .spec-list .arrow-prev:hover i svg {
              color: #999999;
          }
          
          .preview .spec-list .arrow-prev.disabled i svg {
              color: #DFDFDF;
          }
          
          .preview .spec-list .arrow-next {
              right: 0
          }
          
          .preview .spec-list .arrow-next:hover i svg {
              color: #999999;
          }
          
          .preview .spec-list .arrow-next.disabled i svg {
              color: #DFDFDF;
          }
          
          .preview .spec-items {
              width: 224px;
              margin: 0 auto;
              overflow: hidden
          }
          
          .preview .spec-items ul {
              width: 2000px
          }
          
          .preview .spec-items ul li {
              float: left;
              margin: 0 9px;
              max-width: 60px;
              max-height: 70px
          }
          
          .preview .spec-items ul li img {
              border: 2px solid #fff;
              padding-bottom: 1px
          }
          
          .preview .spec-items ul li.img-hover img,.preview .spec-items ul li:hover img {
              border: 2px solid #e53e41
          }
          
          .preview #spec-img {
              max-height: 600px;
          }
          
          .preview .spec-list .spec-items {
              width: 390px
          }
          

          JavaScript交互

          js主要處理鼠標hover到縮略圖更新主圖區域圖片的src屬性值,以及縮略圖的紅色邊框效果;以及實現左右側箭頭點擊產生的縮略圖列表左右滑動效果、箭頭失效處理,注意js中是直接設置ul的left屬性值,要實現滑動的動畫效果,需要在css樣式中設置transition屬性為left 0.5s ease,否則就不會產生動畫效果。


          主站蜘蛛池模板: 国产aⅴ一区二区三区| 亚洲sm另类一区二区三区| 国产午夜精品片一区二区三区| 69久久精品无码一区二区| 伊人色综合网一区二区三区| 极品少妇伦理一区二区| 成人免费一区二区无码视频| 日韩精品无码一区二区三区| 一区二区三区四区国产| 国产精品538一区二区在线| 人妻AV一区二区三区精品| 国产成人高清精品一区二区三区| 国产一区二区草草影院| 一区二区三区在线观看| 精品人妻AV一区二区三区 | 亚洲熟女少妇一区二区| 日本一区二区三区精品视频| 风间由美在线亚洲一区| av无码免费一区二区三区| 日韩精品一区二区三区色欲AV| 国产观看精品一区二区三区| 亚洲AⅤ无码一区二区三区在线| 国产伦精品一区二区三区精品| 一区二区三区在线观看免费| 91视频一区二区三区| 亚洲国产欧美一区二区三区| 亚洲大尺度无码无码专线一区| 国产精品一区二区久久精品| 亚洲乱码av中文一区二区| 国精产品一区一区三区MBA下载| 国精产品一区一区三区MBA下载 | 波多野结衣AV无码久久一区 | 日本激情一区二区三区| 亚洲欧洲精品一区二区三区| 国产福利91精品一区二区三区| 无码播放一区二区三区| 日韩高清一区二区| 国产精品电影一区二区三区 | 日本中文字幕在线视频一区| 波多野结衣高清一区二区三区| 亚洲码一区二区三区|