Vueはシンプルなスライダー検証を実装する

Vueはシンプルなスライダー検証を実装する

この記事の例では、Vueスライダー検証の実装を共有しています。コードは次のとおりです。

<テンプレート>
  <div class="ドラッグ"
       ref="ドラッグDiv">
    <div class="drag_bg"></div>
    <div class="drag_text">{{confirmWords}}</div>
    <div ref="moveDiv"
         @mousedown="mousedownFn($event)"
         :class="{'handler_ok_bg':成功を確認}"
         クラス="ハンドラー handler_bg"
         スタイル="位置: 絶対;上: 0px;左: 0px;"></div>
  </div>
</テンプレート>

<スクリプト>
エクスポートデフォルト{
  データ () {
    戻る {
      beginClientX: 0, /* 画面の左端からの距離*/
      mouseMoveStata: false, /* ドラッグステータスの判定をトリガー*/
      maxwidth: '', /* スライダーの幅に基づいて計算された最大ドラッグ幅*/
      confirmWords: 'スライダーをドラッグして確認します', /* スライダーテキスト*/
      confirmSuccess: false /* 検証成功判定*/
    }
  },
  メソッド: {
    mousedownFn: 関数 (e) {
      成功の確認の場合
        e.preventDefault && e.preventDefault() // テキスト選択などのブラウザのデフォルトイベントを防止 this.mouseMoveStata = true
        this.beginClientX = e.clientX
      }
    }, // マウス終了イベント successFunction () {
      this.confirmSuccess = true
      this.confirmWords = '検証に合格しました'
      ウィンドウにイベントリスナーを追加する場合
        document.getElementsByTagName('html')[0].removeEventListener('mousemove', this.mouseMoveFn)
        document.getElementsByTagName('html')[0].removeEventListener('mouseup', this.moseUpFn)
      } それ以外 {
        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'
    }, // 成功を確認する function mouseMoveFn (e) {
      if (this.mouseMoveStata) {
        幅 = e.clientX - this.beginClientX とします。
        幅 > 0 && 幅 <= this.maxwidth の場合 {
          document.getElementsByClassName('handler')[0].style.left = 幅 + 'px'
          document.getElementsByClassName('drag_bg')[0].style.width = 幅 + 'px'
        } そうでない場合 (幅 > this.maxwidth) {
          this.successFunction()
        }
      }
    }, // マウス移動イベント moseUpFn (e) {
      this.mouseMoveStata = false
      var 幅 = e.clientX - this.beginClientX
      幅が this.maxwidth より小さい場合
        document.getElementsByClassName('handler')[0].style.left = 0 + 'px'
        document.getElementsByClassName('drag_bg')[0].style.width = 0 + 'px'
      }
    } // マウスアップイベント},
  マウントされた(){
    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)
  }
}
</スクリプト>

<スタイルスコープ>
.ドラッグ{
  位置: 相対的;
  背景色: #e8e8e8;
  幅: 30%;
  高さ: 34px;
  行の高さ: 34px;
  テキスト配置: 中央;
}
.ハンドラ{
  幅: 40px;
  高さ: 32px;
  境界線: 1px 実線 #ccc;
  カーソル: 移動;
}
.ハンドラ_bg {
  背景: #fff
    url('')
    繰り返しのないセンター。
}
.handler_ok_bg {
  背景: #fff
    url( 'data:image/png; base64、ivborw0kggoaaaanasuaabaaaaaqcayaaaaf8/9haaaagxrfwhrtb2z0d2fyzqbbzg9izsbjbjbwfnzvjlywr5hmnzvmnzvnvzのbasezg9izsbjbjbwfnzvjlvza aaaaadw/ehbhy2tldcbizwdpbj0i77u/iibpzd0ivzvnme1wq2voauh6cmvtek5uy3pryzlkij8 ++ idwvcmrmokrllc2nyaxb0aw9upia8lhjkzjpsrey+idwvevey+idwvevey+idwvevey+idwvevey+idwvevey+idwvcmrmokrllc2nyaxb0wia9upia ZXQGZW5KPSJYIJ8+K+SHWWAAASZJREFUENPI/P // PWMYKD8UZW+KUODYEYGLOMIVGHGG/EM/PTHX0EFK9I8WAOEZ+IDUPIIMY8IN1QJWENOGJ3ACO5GNABMAXAXA4GIGNJ0MI4GYNJ0MI4GIGNJ0IGNJ0MI4GYNJ0MI4GY4GIGNJ0MI4GY4GY4GY4GY4GY4GY4GY4GY4GY4GY4GY4GY4GY4 +amamj78aedtbiwgyg5gbifcsxfczoabmcy4a4gojnh0d6d6dpk4ixnsvihafsdoaelrajrjgjp/awpbhmhejiqnwyrmuznq4vqgdqqxk0ia/0i17wjipmqmqipmqmqをbekgxsajiieusbnnsbdweay9mefgmmgbk00e0izta7ahectdq58mrua6wllggfmmompig1qfegwaixgzo8giysmwqgsazgwhaezhicizoabkjkqymiaabjaabjaaabjaabgjaabgjaabgjaabgjaabgjaabgggggsgsgwhaezhicizoabkjkqymia
    繰り返しのないセンター。
}
.drag_bg {
  背景色: #7ac23c;
  高さ: 34px;
  幅: 0px;
}
.ドラッグテキスト{
  位置: 絶対;
  上: 0px;
  幅: 100%;
  テキスト配置: 中央;
  -moz-user-select: なし;
  -webkit-user-select: なし;
  ユーザー選択: なし;
  -o-ユーザー選択: なし;
  -ms-user-select: なし;
}
</スタイル>

効果図は以下のとおりです

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • Vue+elementui でスライダーのドラッグパズル検証を実現
  • Vue がモバイル スライダー検証を実装
  • Vueはログイン時にスライダー検証を実装します
  • スライダー検証のために Vue と Alibaba Cloud を統合する実践
  • Vue3+Vue-cli4 プロジェクトで Tencent スライダー検証コードを使用する方法
  • konva および vue-konva ライブラリを使用してドラッグスライダー検証機能を実装します。
  • VUEアクセステンセント認証コード機能(スライダー認証)メモ
  • Vue はドラッグ スライダー検証機能を実装します (バックグラウンド検証手順のない CSS + JS のみ)
  • vue-cli カスタムディレクティブ ディレクティブ 検証スライダーの追加例
  • Vueで画像スライダー検証コンポーネントをカプセル化する方法

<<:  MySQLで更新可能なビューを作成する方法の詳細な説明

>>:  Nginx を使用してグレースケール リリースを実装する

推薦する

ページネーションの例とベストプラクティス

<br />構造と階層により複雑さが軽減され、読みやすさが向上します。記事やサイトが整理...

Spring Cloud での Docker デプロイメントに jib を使用する詳細な手順

ジブの紹介Jib は Google が開発した、Java アプリケーションの Docker および ...

MySQL 5.x 以降を使用している場合のエラー #1929 列 ''createtime'' の日付時刻値が正しくありません: '''' の簡単な解決方法

MySQL をインストールした後、テーブル データを保存および削除しようとすると、常にエラー メッセ...

JSは10進数を16進数に変換するサンプルコードを実装します

序文コードを書くと、時々基数変換の問題に遭遇します。一般的な変換には、2進数、8進数、10進数、16...

mysql5.7 のエンコーディングを utf8mb4 に設定する方法

最近、問題に遭遇しました。モバイル端末の絵文字や一部の絵文字は 4 バイトですが、UTF-8 は 3...

XHTML Web ページ チュートリアル

この記事は主に、初心者に XHTML の基本的な知識と、XHTML と HTML の違いを理解しても...

DIV+CSS命名規則の詳細な説明はSEO最適化に役立ちます

1. CSSファイルの命名規則提案: 文字、_、-、数字を使用します。文字で始まる必要があり、純粋な...

Google の新しい UI から学べること (画像とテキスト)

2011 年に最も顕著なウェブサイトの変更は、一連の製品に新しいユーザー インターフェースを導入した...

Docker で Redis センチネル モードを構成する方法 (複数のサーバー上)

目次序文状態DockerをインストールするRedisのマスターノードとスレーブノードを構成する序文以...

CSS でマウスの位置をマッピングし、マウスを動かしてページ要素を制御する (サンプル コード)

マウスの位置をマッピングしたり、ドラッグ効果を実装したりすることは、 JavaScriptで行うこと...

jsオブジェクト指向カプセル化カスケードドロップダウンメニューリストの実装手順

この例で開発されたカスケード ドロップダウン メニューは、既存の JSON データに基づいて作成され...

CSS3マスクレイヤーのくり抜き効果を実現するさまざまな方法

この記事では、マスク レイヤーの中空化を実現する 4 つの方法を紹介します。みんなと共有し、自分用の...

MySQL システム ユーザーが開くことができるファイルの最大数に関する簡単な説明

本から学ぶことは常に浅はかで、これがさらなるダウンタイムを引き起こすことには決して気づきません......

Linux で MySQL のルート パスワードを変更する方法

序文このサービスは数か月前からMySQLに導入されています。私の仕事は基本的にターミナルで行われるた...

sshとは何ですか?使い方は?どのような誤解があるのでしょうか?

目次序文SSHとは何かssh は何に使用されますか? sshの使い方ssh 再修正要約する序文ssh...