ホームページ > ウェブフロントエンド > jsチュートリアル > jQueryとvueを使ったドラッグ検証コード機能の実装方法

jQueryとvueを使ったドラッグ検証コード機能の実装方法

亚连
リリース: 2018-06-08 18:10:17
オリジナル
2194 人が閲覧しました

この記事では主に、非常にシンプルな緑色のドラッグ検証コード関数を実装するための jQuery と vue と、それを必要とする友人がそこから学ぶことができるコード例を紹介します。

jqueryの緑色のドラッグ検証機能

ネットでこんな質問を見かけました:グラフィックスに合わせてスライダーをドラッグするような検証方法はどのように実装されていますか? 。

シンプルな緑色のドラッグ検証コード関数を実装することを突然思いつき、オンラインで検索したところ、jqueryで実装されたこの関数のコードを見つけました。

体験アドレス: http://yanshi.sucaihuo.com/jquery/8/897/demo/

CSS コード:

#drag{ 
  position: relative;
  background-color: #e8e8e8;
  width: 300px;
  height: 34px;
  line-height: 34px;
  text-align: center;
}
#drag .handler{
  position: absolute;
  top: 0px;
  left: 0px;
  width: 40px;
  height: 32px;
  border: 1px solid #ccc;
  cursor: move;
}
.handler_bg{
  background: #fff url("") no-repeat center;
}
.handler_ok_bg{
  background: #fff url("") no-repeat center;
}
#drag .drag_bg{
  background-color: #7ac23c;
  height: 34px;
  width: 0px;
}
#drag .drag_text{
  position: absolute;
  top: 0px;
  width: 300px;
  -moz-user-select: none;
  -webkit-user-select: none;
  user-select: none;
  -o-user-select:none;
  -ms-user-select:none; 
}
ログイン後にコピー

HTML コード構造:

<center style="margin-top: 100px">
  <p id="drag"></p>
</center>
ログイン後にコピー

JS 呼び出しメソッド:

$(&#39;#drag&#39;).drag();
ログイン後にコピー

JS 実装コード:

(function($){
  $.fn.drag = function(options){
    var x, drag = this, isMove = false, defaults = {
    };
    var options = $.extend(defaults, options);
    //添加背景,文字,滑块
    var html = &#39;<p class="drag_bg"></p>&#39;+
          &#39;<p class="drag_text" onselectstart="return false;" unselectable="on">拖动滑块验证</p>&#39;+
          &#39;<p class="handler handler_bg"></p>&#39;;
    this.append(html);
    
    var handler = drag.find(&#39;.handler&#39;);
    var drag_bg = drag.find(&#39;.drag_bg&#39;);
    var text = drag.find(&#39;.drag_text&#39;);
    var maxWidth = drag.width() - handler.width(); //能滑动的最大间距
    
    //鼠标按下时候的x轴的位置
    handler.mousedown(function(e){
      isMove = true;
      x = e.pageX - parseInt(handler.css(&#39;left&#39;), 10);
    });
    
    //鼠标指针在上下文移动时,移动距离大于0小于最大间距,滑块x轴位置等于鼠标移动距离
    $(document).mousemove(function(e){
      var _x = e.pageX - x;
      if(isMove){
        if(_x > 0 && _x <= maxWidth){
          handler.css({&#39;left&#39;: _x});
          drag_bg.css({&#39;width&#39;: _x});
        }else if(_x > maxWidth){ //鼠标指针移动距离达到最大时清空事件
          dragOk();
        }
      }
    }).mouseup(function(e){
      isMove = false;
      var _x = e.pageX - x;
      if(_x < maxWidth){ //鼠标松开时,如果没有达到最大距离位置,滑块就返回初始位置
        handler.css({&#39;left&#39;: 0});
        drag_bg.css({&#39;width&#39;: 0});
      }
    });
    
    //清空事件
    function dragOk(){
      handler.removeClass(&#39;handler_bg&#39;).addClass(&#39;handler_ok_bg&#39;);
      text.text(&#39;验证通过&#39;);
      drag.css({&#39;color&#39;: &#39;#fff&#39;});
      handler.unbind(&#39;mousedown&#39;);
      $(document).unbind(&#39;mousemove&#39;);
      $(document).unbind(&#39;mouseup&#39;);
    }
  };
})(jQuery);
ログイン後にコピー

VUEのグリーンドラッグ検証機能

HTML構造:

<template>
  <p id="drag">
    <p class="drag_bg weui-btn_primary" :style="{width:curW+&#39;px&#39;}"></p>
    <p class="drag_text" onselectstart="return false;" unselectable="on":class="[isDragOk ? &#39;whitecolor&#39;:&#39;&#39;]">{{text}}</p>
    <p class="handler" :style="{left:curW+&#39;px&#39;}" :class="[isDragOk ? &#39;handler_ok_bg&#39;:&#39;handler_bg&#39;]"></p>
  </p>
</template>
ログイン後にコピー

CSSコード:

<style scoped>
#drag {
  position: relative;
  background-color: #e8e8e8;
  width: 100%;
  height: 36px;
  line-height: 36px;
  text-align: center;
}
#drag .drag_bg {
  height: 36px;
  width:0;
}
#drag .drag_text {
  position: absolute;
  top: 0px;
  width: 100%;
  -moz-user-select: none;
  -webkit-user-select: none;
  user-select: none;
  -o-user-select: none;
  -ms-user-select: none;
}
.drag_text.whitecolor{
  color:#fff;
}
#drag .handler {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 40px;
  height: 34px;
  border: 1px solid #ccc;
  cursor: move;
}
.handler_bg {
  background:#fff url("") no-repeat center
}
.handler_ok_bg {
  background:#fff url("") no-repeat center
}
</style>
ログイン後にコピー

JSコード:

<script>
export default{
  name:&#39;slider&#39;,
  props:{
    
  },
  data(){
    return{
      curW:0,
      isMove:false, //是否在运动
      isDragOk:false, //是否拖动成功
      maxWidth:0, //拖动的最大宽度
      element:{},
      text:&#39;拖动滑块验证&#39;,
      currentPos:{
        x: 0,
        y: 0
      }
    }
  },
  created(){
    
  },
  mounted () {
    var self = this;
    this.element = document.querySelector(&#39;.handler&#39;);
    this.getMaxWidth();
    window.addEventListener(&#39;resize&#39;,function(){self.getMaxWidth()});
    window.addEventListener(&#39;orientationchange&#39;,function(){self.getMaxWidth()});
    
    
     this.element.addEventListener(&#39;touchstart&#39;,self.touchstartFun,false);
    document.querySelector(&#39;body&#39;).addEventListener(&#39;touchmove&#39;,self.touchmoveFun,false);
    document.querySelector(&#39;body&#39;).addEventListener(&#39;touchend&#39;,self.touchendFun,false);
    
    this.element.addEventListener(&#39;mousedown&#39;,self.touchstartFun,false);
    document.querySelector(&#39;body&#39;).addEventListener(&#39;mousemove&#39;,self.touchmoveFun,false);
    document.querySelector(&#39;body&#39;).addEventListener(&#39;mouseup&#39;,self.touchendFun,false);
    
    (function drawAnimate() {
      if( self.curW <= self.maxWidth){
        window.requestAnimFrame(drawAnimate,1000/60);
        self.curW = self.currentPos.x;
      }else{
        self.curW = self.currentPos.x = self.maxWidth;
      }
    })();
  },
  watch:{
    
  },
  methods:{
    touchstartFun(e){
      if(this.isDragOk){
         e.preventDefault();
         return;
       }
      this.isMove = true;
      this.curW = this.currentPos.x = this.getCurrentPosition(e).x;
    },
    touchmoveFun(e){
      if(this.isMove && this.curW > 0 && this.curW < this.maxWidth){
        this.currentPos.x = this.getCurrentPosition(e).x;
      }
      else if(this.isMove && this.curW >= this.maxWidth){
        this.curW = this.currentPos.x = this.maxWidth;
        this.isDragOk = true;
        this.text = "验证通过";
      }
    },
    touchendFun(e){
      this.isMove = false;
      if(this.curW < this.maxWidth){
        this.curW = this.currentPos.x = 0;
      }
    },
    
    getCurrentPosition(event){
      var xPos, yPos, rect;
      rect = document.getElementById(&#39;drag&#39;).getBoundingClientRect();
      //event = event.originalEvent;
      //判断是touch,还是鼠标事件
      if (event.type.indexOf(&#39;touch&#39;) !== -1) {
        xPos = event.touches[0].clientX - rect.left;
        yPos = event.touches[0].clientY - rect.top;
      }
      
      //鼠标事件
      else {
        xPos = event.clientX - rect.left;
        yPos = event.clientY - rect.top;
      }
      return {
        x: xPos,
        y: yPos
      }
    },
    getMaxWidth(){
      this.maxWidth = document.querySelector("#drag").clientWidth - document.querySelector(".handler").scrollWidth;
    }
  }
}
</script>
ログイン後にコピー

ページ参照方法:

<slider></slider>
ログイン後にコピー

上記は皆さんのためにまとめたものです、参考になれば幸いです今後とも皆様のお役に立ちますように。

関連記事:

vue-cliでbabel設定ファイルを設定する方法

babelのインストールと設定チュートリアルの使い方

gm Croppingを使用してNodejsで画像を合成する

以上がjQueryとvueを使ったドラッグ検証コード機能の実装方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート