この記事の例では、どこにでも移動できるフローティングボタンを実現するためのVueの具体的なコードを共有しています。具体的な内容は次のとおりです。 1.htmlコード <div class="コールバックフロート" @click="クリック時" @mousedown="下" @touchstart="下" @mousemove="移動" @touchmove="移動" @mouseup="終了" @touchend="終了" ref="fu" > <!-- <p @click="callback">戻る</p> --> <img @click="コールバック" src="@/assets/images/callbs.jpg" alt /> </div> 2. データで定義する データ() { 戻る { isLoading: false、 flags: false, //コントロール使用位置: { x: 0, y: 0, }, 索引: "", ny: "", dx: "", dy: "", xPum: "", yPum: "", }; }, 3.jsコード メソッド: { 折り返し電話() { $router.go(-1); }, リフレッシュ() { // ウィンドウの場所を再読み込みします。 setTimeout((res) => { コンソールログ(res); this.isLoading = false; }, 1000); }, 下() { this.flags = true; var タッチ; if (イベント.タッチ) { タッチ = イベント.タッチ[0]; } それ以外 { タッチ = イベント; } this.position.x = touch.clientX; this.position.y = touch.clientY; this.dx = this.$refs.fu.offsetLeft; this.dy = this.$refs.fu.offsetTop; }, 動く() { if (this.flags) { var タッチ; if (イベント.タッチ) { タッチ = イベント.タッチ[0]; } それ以外 { タッチ = イベント; } this.nx = touch.clientX - this.position.x; this.ny = touch.clientY - this.position.y; this.xPum = this.dx + this.nx; this.yPum = this.dy + this.ny; let width = window.innerWidth - this.$refs.fu.offsetWidth; // 画面の幅からコントロールの幅を引いた値 let height = window.innerHeight - this.$refs.fu.offsetHeight; // 画面の高さからコントロールの高さを引いた値 this.xPum < 0 && (this.xPum = 0); this.yPum < 0 && (this.yPum = 0); this.xPum > 幅 && (this.xPum = 幅); this.yPum > 高さ && (this.yPum = 高さ); // if (this.xPum >= 0 && this.yPum >= 0 && this.xPum<= 幅 &&this.yPum<= 高さ) { this.$refs.fu.style.left = this.xPum + "px"; this.$refs.fu.style.top = this.yPum + "px"; // } //デフォルトでページがスライドしないようにする document.addEventListener( 「タッチムーブ」、 関数 () { イベントをデフォルトにしない(); }, 間違い ); } }, //マウスが離されたときの関数 end() { this.flags = false; }, クリック() { //ここではこれをサブコンポーネントとして使用しています。this.$emit("click"); }, }, 4.スタイル <スタイルスコープ> .コールバックp{ フォントサイズ: 16px; 色: #fff; 背景: rgba(56, 57, 58, 0.5); 境界線の半径: 50%; テキスト配置: 中央; 幅: 50px; 高さ: 50px; 行の高さ: 50px; フォントファミリー: PingFang SC; フォントの太さ: 600; ボックスシャドウ: 0 0 10px #fff; } .コールバック画像{ 表示: ブロック; 幅: 50px; 高さ: 50px; ボックスシャドウ: 0 0 10px rgb(133, 129, 129); 境界線の半径: 50%; 背景: #fff; } 。折り返し電話 { 位置: 固定; 上: 40px; 左: 20px; zインデックス: 99999; } .float { 位置: 固定; 右: 20px; 上位: 60% タッチアクション: なし; テキスト配置: 中央; 幅: 50px; 高さ: 50px; 境界線の半径: 24px; 行の高さ: 48px; 色: 白; } </スタイル> 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: Ubuntu Server のターミナルのウェルカム メッセージで広告を無効にする方法
>>: エラー mysql テーブル 'performance_schema...解決方法
システムをコンピューターにインストールする方法がわからない場合は、Linux を学習したい場合は、仮...
この記事では、ローカル マシンに Java 8 をインストールせずに、Java 8 を使用して簡単な...
インターネットに接続できない仮想マシンをセットアップするのは非常に面倒です。ここでは、Ubuntu ...
以前、「Web ページにシステムに組み込まれていないフォントを埋め込む」という研究をしたことがありま...
Unicode は、世界中のすべてのテキストと記号に対応できる国際組織によって開発された文字エンコー...
なぜなら、SQL Server 2005 に基づくデータベース チュートリアルがあり、そこで使用され...
実際には、N 秒後にページを自動的にジャンプさせるにはどうすればよいかという問題によく遭遇します。私...
この記事の例では、滝の流れの効果を実現するためのjsの具体的なコードを参考までに共有しています。具体...
目次SSHプロトコルパスワード接続プロセスsshツールssh公開鍵ログインバッチ操作複数サーバーファ...
コーディングをしていると、多くのことが同じ結末を迎えることに気づくでしょう。問題を解決する方法は何千...
JavaScriptコントロールを使用したくない場合は、次の方法を試してください。 Safariブラ...
私が使用しているデータベースはMySQLデータベースバージョン5.7ですまずデータベーステーブルを自...
「開発とは、単にコードを書くだけではない」というのは、3EV の Dan Frost 氏の言葉です。...
11. JavaScriptを使用してページ効果を作成する11.1 DOMプログラミングDOM プロ...
コンテナデータボリュームとはデータがコンテナ内にある場合、コンテナを削除するとデータは失われます。例...