tui-slide-verify.vue 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. <template>
  2. <view class="tui-slide-vcode" :style="{width:slideBarWidth+'px',height:slideBlockWidth+'px',backgroundColor:backgroundColor}">
  3. <text class="tui-text-flashover" :style="{fontSize:size+'rpx',background:getBgColor}">拖动滑块验证</text>
  4. <view class="tui-slide-glided" :style="{backgroundColor:activeBgColor}">
  5. <text :style="{fontSize:size+'rpx',color:activeColor}" v-if="isPass">{{passText}}</text>
  6. </view>
  7. <view class="tui-slider-block" :style="{width:slideBlockWidth+'px',height:slideBlockWidth+'px',borderColor:isPass?activeBorderColor: borderColor}"
  8. :change:prop="parse.slidereset" :prop="reset" :data-slideBarWidth="slideBarWidth" :data-slideBlockWidth="slideBlockWidth"
  9. :data-errorRange="errorRange" :data-disabled="disabled" @touchstart="parse.touchstart" @touchmove="parse.touchmove"
  10. @touchend="parse.touchend">
  11. <text class="tui-slide-icon tui-icon-double_arrow" :style="{fontSize:iconSize+'rpx',color:arrowColor}" v-if="!isPass"></text>
  12. <text class="tui-slide-icon tui-icon-check_mark" :style="{fontSize:iconSize+'rpx',color:checkColor}" v-if="isPass"></text>
  13. </view>
  14. </view>
  15. </template>
  16. <script src="./tui-slide-verify.wxs" module="parse" lang="wxs"></script>
  17. <script>
  18. export default {
  19. name: "tuiSlideVerify",
  20. props: {
  21. //滑动条宽度 px
  22. slideBarWidth: {
  23. type: [Number, String],
  24. default: 300
  25. },
  26. //滑块宽度 px = 滑动条高度
  27. slideBlockWidth: {
  28. type: [Number, String],
  29. default: 40
  30. },
  31. //滑块border颜色
  32. borderColor: {
  33. type: String,
  34. default: '#E9E9E9'
  35. },
  36. //通过验证后滑块border颜色
  37. activeBorderColor: {
  38. type: String,
  39. default: '#19be6b'
  40. },
  41. //误差范围 px 距离右侧多少距离验证通过
  42. errorRange: {
  43. type: [Number, String],
  44. default: 2
  45. },
  46. //重置滑动
  47. resetSlide: {
  48. type: Number,
  49. default: 0
  50. },
  51. //提示文字大小
  52. size: {
  53. type: Number,
  54. default: 30
  55. },
  56. //提示文字颜色
  57. color: {
  58. type: String,
  59. default: "#444"
  60. },
  61. //验证通过后提示文字颜色
  62. activeColor: {
  63. type: String,
  64. default: "#fff"
  65. },
  66. //图标字体大小 rpx
  67. iconSize: {
  68. type: Number,
  69. default: 32
  70. },
  71. //箭头图标颜色
  72. arrowColor: {
  73. type: String,
  74. default: "#cbcbcb"
  75. },
  76. checkColor: {
  77. type: String,
  78. default: "#19be6b"
  79. },
  80. //滑动条背景色
  81. backgroundColor: {
  82. type: String,
  83. default: "#E9E9E9"
  84. },
  85. //滑过区域背景颜色
  86. activeBgColor: {
  87. type: String,
  88. default: "#19be6b"
  89. },
  90. //通过提示文字
  91. passText: {
  92. type: String,
  93. default: '验证通过'
  94. }
  95. },
  96. computed: {
  97. getBgColor() {
  98. return `-webkit-gradient(linear, left top, right top, color-stop(0, ${this.color}), color-stop(.4, ${this.color}), color-stop(.5, white), color-stop(.6, ${this.color}), color-stop(1, ${this.color}))`
  99. }
  100. },
  101. watch: {
  102. resetSlide(val) {
  103. if (val > 0) {
  104. this.slideReset()
  105. }
  106. }
  107. },
  108. data() {
  109. return {
  110. isPass: false,
  111. disabled: false,
  112. reset: 0
  113. }
  114. },
  115. methods: {
  116. success() {
  117. //验证成功
  118. this.isPass = true;
  119. this.disabled = true;
  120. this.$emit('success', {})
  121. },
  122. slideReset() {
  123. this.isPass = false;
  124. this.disabled = false;
  125. this.reset++;
  126. }
  127. }
  128. }
  129. </script>
  130. <style scoped>
  131. @font-face {
  132. font-family: 'tuiSlideVcode';
  133. src: url(data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAAAUYAA0AAAAAB1wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAE/AAAABoAAAAci6lfG0dERUYAAATcAAAAHgAAAB4AKQALT1MvMgAAAaAAAABCAAAAVjxuSCZjbWFwAAAB+AAAAEUAAAFK5n3pi2dhc3AAAATUAAAACAAAAAj//wADZ2x5ZgAAAkwAAAD8AAABJDQ/n7JoZWFkAAABMAAAADAAAAA2GSR8FGhoZWEAAAFgAAAAHQAAACQHygOFaG10eAAAAeQAAAARAAAAEgwUAD5sb2NhAAACQAAAAAwAAAAMAFQAkm1heHAAAAGAAAAAHgAAACABEQA6bmFtZQAAA0gAAAFJAAACiCnmEVVwb3N0AAAElAAAAD0AAABPYJEgVXjaY2BkYGAA4oqPSw3j+W2+MnCzMIDAbaY5nHBa5P905jfMeUAuBwMTSBQAHycKCHjaY2BkYGBu+N/AEMPCAALMbxgYGVABCwBYegNYAAAAeNpjYGRgYGBl0GNgYgABEMkFhAwM/8F8BgANfQFMAAB42mNgZGFgnMDAysDA1Ml0hoGBoR9CM75mMGLkAIoysDIzYAUBaa4pDA7PGJ6ZMDf8b2CIYW5gaAAKM4LkAN6ZDA8AAHjaY2GAABYItmMQAQABaABfAAAAeNpjYGBgZoBgGQZGBhBwAfIYwXwWBg0gzQakGRmYnjE8M/n/n4EBQksxS16AqgcCRjYGOIeRCUgwMaACRoZhDwDR6wnSAAAAAAAAAAAAAAAAVACSeNpFzjFOwzAYxfHv2Yodu4ozxHEq2qoSEilLQYoqh6lIIBaugMTC3hswMcPQhYmBjV4AMSFxAppjQDmDSzJle9L7DX9itNx/8i9+QY7mRPDn8ItTlDOcQLhCwcBVtWLCOl/D10v0L5vHnAGMx+EuLSctvQ8PBpMyxWU30/GxwUvMwXqDW6lkNIikllgnGM1MeAqPyWxkeNktczRGgrXUXOkeETGy+2f+x1c0oGnbKUg6KjzVJWUQh23TwlfTrhW+cpZRE3ZCIG8a5EKE3U34yM/sRttCb5hiuNLDjK+i8PO9Db8igmu2cOE1vNsWDTP9xhiuVXZARP+yvTqbeNp9kD1OAzEQhZ/zByQSQiCoXVEA2vyUKRMp9Ailo0g23pBo1155nUg5AS0VB6DlGByAGyDRcgpelkmTImvt6PObmeexAZzjGwr/3yXuhBWO8ShcwREy4Sr1F+Ea+V24jhY+hRvUf4SbuFUD4RYu1BsdVO2Eu5vSbcsKZxgIV3CKJ+Eq9ZVwjfwqXMcVPoQb1L+EmxjjV7iFa2WpDOFhMEFgnEFjig3jAjEcLJIyBtahOfRmEsxMTzd6ETubOBso71dilwMeaDnngCntPbdmvkon/mDLgdSYbh4FS7YpjS4idCgbXyyc1d2oc7D9nu22tNi/a4E1x+xRDWzU/D3bM9JIbAyvkJI18jK3pBJTj2hrrPG7ZynW814IiU68y/SIx5o0dTr3bmniwOLn8owcfbS5kj33qBw+Y1kIeb/dTsQgil2GP5PYcRkAAAB42mNgYoAALjDJyIAOWMGiTIxMjMyCOalpJbop+aVJOam6iUVF+eUCKaWZ6fmlJZmJeckZ+XnpugDvDw1eAAAAAAAAAf//AAIAAQAAAAwAAAAWAAAAAgABAAMABAABAAQAAAACAAAAAHjaY2BgYGQAgqtL1DlA9G2mOZwwGgA1wQSuAAA=) format('woff');
  134. font-weight: normal;
  135. font-style: normal;
  136. font-display: swap;
  137. }
  138. .tui-slide-icon {
  139. font-family: "tuiSlideVcode" !important;
  140. font-size: 34rpx;
  141. font-style: normal;
  142. -webkit-font-smoothing: antialiased;
  143. }
  144. .tui-icon-check_mark:before {
  145. content: "\e634";
  146. }
  147. .tui-icon-double_arrow:before {
  148. content: "\e600";
  149. }
  150. .tui-slide-vcode {
  151. background-color: #EAEEF1;
  152. position: relative;
  153. display: flex;
  154. align-items: center;
  155. justify-content: center;
  156. }
  157. .tui-slide-glided {
  158. width: 0;
  159. height: 100%;
  160. background-color: #19BE6B;
  161. position: absolute;
  162. left: 0;
  163. top: 0;
  164. z-index: 1;
  165. display: flex;
  166. align-items: center;
  167. justify-content: center;
  168. }
  169. .tui-slider-block {
  170. position: absolute;
  171. z-index: 2;
  172. background-color: #FFFFFF;
  173. height: 100%;
  174. display: flex;
  175. align-items: center;
  176. justify-content: center;
  177. border: 1rpx solid;
  178. box-sizing: border-box;
  179. left: 0;
  180. top: 0;
  181. transition: border-color 0.08s;
  182. }
  183. .tui-text-flashover {
  184. -webkit-background-clip: text !important;
  185. -webkit-text-fill-color: transparent !important;
  186. -webkit-animation: animate 1.8s infinite;
  187. }
  188. @-webkit-keyframes animate {
  189. from {
  190. background-position: -90rpx;
  191. }
  192. to {
  193. background-position: 90rpx;
  194. }
  195. }
  196. @keyframes animate {
  197. from {
  198. background-position: -90rpx;
  199. }
  200. to {
  201. background-position: 90rpx;
  202. }
  203. }
  204. </style>