Rumah > hujung hadapan web > tutorial js > jQuery与vue做出拖动验证的验证码效果

jQuery与vue做出拖动验证的验证码效果

php中世界最好的语言
Lepaskan: 2018-03-14 18:10:06
asal
3204 orang telah melayarinya

这次给大家带来jQuery与vue做出拖动验证的验证码效果,用jQuery与vue做出拖动验证的验证码效果注意事项有哪些,下面就是实战案例,一起来看一下。

其CSS代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

#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; 

}

Salin selepas log masuk

HTML代码结构:

1

2

3

<center style="margin-top: 100px">

  <p id="drag"></p>

</center>

Salin selepas log masuk

JS调用方式:

1

$('#drag').drag();

Salin selepas log masuk

JS实现代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

(function($){

  $.fn.drag = function(options){

    var x, drag = this, isMove = false, defaults = {

    };

    var options = $.extend(defaults, options);

    //添加背景,文字,滑块

    var html = '<p class="drag_bg"></p>'+

          '<p class="drag_text" onselectstart="return false;" unselectable="on">拖动滑块验证</p>'+

          '<p class="handler handler_bg"></p>';

    this.append(html);   

    var handler = drag.find('.handler');

    var drag_bg = drag.find('.drag_bg');

    var text = drag.find('.drag_text');

    var maxWidth = drag.width() - handler.width(); //能滑动的最大间距    

    //鼠标按下时候的x轴的位置

    handler.mousedown(function(e){

      isMove = true;

      x = e.pageX - parseInt(handler.css('left'), 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);

Salin selepas log masuk

VUE的绿色拖动验证功能

HTML结构:

1

2

3

4

5

6

7

<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>

Salin selepas log masuk

CSS代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

<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>

Salin selepas log masuk

JS代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

<script>

export default{

  name:'slider',

  props:{

  },

  data(){

    return{

      curW:0,

      isMove:false, //是否在运动

      isDragOk:false, //是否拖动成功

      maxWidth:0, //拖动的最大宽度

      element:{},

      text:'拖动滑块验证',

      currentPos:{

        x: 0,

        y: 0

      }

    }

  },

  created(){

  },

  mounted () {

    var self = this;

    this.element = document.querySelector('.handler');

    this.getMaxWidth();

    window.addEventListener('resize',function(){self.getMaxWidth()});

    window.addEventListener('orientationchange',function(){self.getMaxWidth()});    

     this.element.addEventListener('touchstart',self.touchstartFun,false);

    document.querySelector('body').addEventListener('touchmove',self.touchmoveFun,false);

    document.querySelector('body').addEventListener('touchend',self.touchendFun,false);

    this.element.addEventListener('mousedown',self.touchstartFun,false);

    document.querySelector('body').addEventListener('mousemove',self.touchmoveFun,false);

    document.querySelector('body').addEventListener('mouseup',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>

Salin selepas log masuk

页面引用方式:

1

<slider></slider>

Salin selepas log masuk

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

jquery+css3做出直播平台的导航

鼠标响应缓冲动画效果如何实现?

如何实现滚动条滑到底部时自动加载更多内容

如何用jquery做出放大镜效果

Atas ialah kandungan terperinci jQuery与vue做出拖动验证的验证码效果. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan