uniAppエディタWeChatスライド問題について

uniAppエディタWeChatスライド問題について

ユニアプリアプレットはWeChatでも同様のドロップダウン問題を抱えることになる

解決策は、app.vueページのonLaunchメソッドにスライドダウンを禁止するメソッドを追加することです。

this.$nextTick(() => {
document.body.addEventListener("touchmove", this.addBodyTouchEvent, {
受動態: 偽
});
});

問題が解決した後、uniAppのエディターコンポーネントをスライドさせることはできません

回避策

データにこれら2つの値を追加します

スライド効果を手動で記述するための touchstart および touchend メソッドを追加します。

タッチスタート(e) {
this.previewScrollTop = e.touches[0].pageY;
},
タッチエンド(e) {
距離をe.changedTouches[0].pageY - this.previewScrollTopとします。
(Math.abs(距離) <= 10) の場合 {
false を返します。
}
//距離が短すぎる場合はスクロールしない let dom = this.$refs.editor.$el.getElementsByClassName("ql-editor")[0],
maxHeight = Math.max(0, dom.scrollHeight - dom.clientHeight), // 最大高さ範囲 tempData = this.scrollTop + (distance >= 0 ? -60 : 60); // 必要な高さデータを計算 if (tempData >= maxHeight) {
this.scrollTop = maxHeight;
DOM のスクロールトップを this.scrollTop に変更します。
} それ以外の場合 (tempData <= 0) {
this.scrollTop = 0;
DOM のスクロールトップを this.scrollTop に変更します。
} それ以外 {
this.scrollTop = tempData;
DOM のスクロールトップを this.scrollTop に変更します。
}
}

このときにスライディング効果が現れます。しかし、滑りがスムーズではありません。

アニメーション化されたトランジション効果を書きたかったのです。しかし。このスライドは、dom.scrollTop プロパティを使用して行われます。このプロパティは CSS プロパティに属していないため、CSS 遷移アニメーションは使用できません。

そこで js メソッドを書きました。

/**
* アニメーションはページ上の指定された位置まで垂直にスクロールします* @param { } dom 要素オブジェクト* @param { Number } currentY 現在の位置* @param { Number } targetY ターゲット位置*/
エクスポート関数 scrollAnimation(dom, currentY, targetY) {
// 移動距離を計算します let needScrollTop = targetY - currentY;
_currentY = currentY とします。
タイムアウトを設定する(() => {
// 呼び出しごとのスライディングフレームの数は毎回異なります。const dist = Math.ceil(needScrollTop / 10);
_currentY += 距離;
dom.scrollTo(_currentY, currentY);
// 移動が 10 ピクセル未満の場合は直接移動し、それ以外の場合はアニメーション効果を実現するために再帰的に呼び出します if (needScrollTop > 10 || needScrollTop < -10) {
scrollAnimation(dom、_currentY、targetY);
} それ以外 {
dom.scrollTo(_currentY, targetY);
}
}, 1);
}

想起

タッチエンド(e) {
距離をe.changedTouches[0].pageY - this.previewScrollTopとします。
(Math.abs(距離) <= 10) の場合 {
false を返します。
}
//距離が短すぎる場合はスクロールしない let dom = this.$refs.editor.$el.getElementsByClassName("ql-editor")[0],
maxHeight = Math.max(0, dom.scrollHeight - dom.clientHeight), // 最大高さ範囲 tempData = this.scrollTop + (distance >= 0 ? -60 : 60); // 必要な高さデータを計算 if (tempData >= maxHeight) {
this.scrollTop = maxHeight;
DOM のスクロールトップを this.scrollTop に変更します。
} それ以外の場合 (tempData <= 0) {
this.scrollTop = 0;
DOM のスクロールトップを this.scrollTop に変更します。
} それ以外 {
this.scrollTop = tempData;
scrollAnimation(dom, 0, this.scrollTop);
}
}

注記:

この質問は、もともと Transform: translateY( y ) プロパティを使用して記述することを意図しており、実際にそのように記述されました。

しかし、やってみると

dom = this.$refs.editor.$el.getElementsByClassName("ql-editor")[0] とします。 

ここで選択されている要素は、赤いボックスの下の要素です。オフセットを実行すると、要素全体がオフセットされます。文書は完全には表示されませんが、その下に大きな空白スペースがあります。その時はスクリーンショットを撮っていませんでした。遭遇した落とし穴を記録します。

uniAppエディターWeChatスライド問題に関するこの記事はこれで終わりです。 uniAppエディターWeChatスライドに関するその他の関連コンテンツについては、123WORDPRESS.COMの以前の記事を検索するか、以下の関連記事を引き続き閲覧してください。 今後とも123WORDPRESS.COMを応援していただければ幸いです。

以下もご興味があるかもしれません:
  • uniapp アプレットでウォーターフォール フロー レイアウトを実装するためのアイデアとコード
  • Uniapp WeChatアプレット: キー障害の解決策
  • uniapp H5 https クロスドメイン リクエストの実装
  • uniappのグローバル変数実装の詳細な説明
  • Uniappは、スライドページコントロール要素の表示と非表示の効果を実現する小さなプログラムを開発しました。
  • Uniapp WeChatアプレットは1ページに複数のカウントダウンを実現します
  • Uniapp 電子商取引アプレットが注文の 30 分カウントダウンを実装
  • Uniappはスライド可能なタブを実装
  • uniappがインターフェースドメイン名を動的に取得する方法を分析する

<<:  JavaScriptにおけるPromiseの使い方と注意点について(推奨)

>>:  vue 要素 el-transfer にドラッグ機能を追加

推薦する

Nginx プロキシを使用してフロントエンドのクロスドメイン問題を解決する方法

序文Nginx (「エンジン エックス」と発音) は、リバース プロキシ、ロード バランサ、HTTP...

MySQLは、where in()順序ソートを実装するためにfind_in_set()関数を使用します。

この記事では、MySQL で find_in_set() 関数を使用して where in() の順...

Centos7 での NFS サービス構築の紹介

目次1. サーバー2. クライアント3. テストサービス1. サーバー1. YUMソースを使用してN...

OEL7.6 ソースコードから MYSQL5.7 をインストールするチュートリアル

まず、公式サイト https://dev.mysql.com/downloads/mysql/5.7...

MySQL DATEDIFF 関数を使用して 2 つの日付間の時間間隔を取得する方法

説明する2 つの日付間の時間間隔を返します。文法DateDiff(間隔、日付1、日付2 [、週の最初...

Vue バインディング オブジェクト、配列データを動的にレンダリングできないケースの詳細な説明

プロジェクトシナリオ: Dark Horse Vueプロジェクト管理の実践、製品分類の取得、拡張バー...

Centos7 での MySQL 5.7.20 のインストールと設定に関する詳細なチュートリアル

1. 公式 Web サイトから MySQL 5.7 インストール パッケージ (mysql-5.7....

Linux echo テキスト処理コマンドの使用法と例

Linux ヘルプ ドキュメントでの echo の説明は、Python や Java などのプログラ...

JavaScript セレクター関数 querySelector および querySelectorAll

目次1. querySelectorは単一の要素を照会する1. ドキュメントインスタンスの呼び出し2...

Linux のメモリ管理とアドレス指定の詳細な紹介

目次1. コンセプトメモリ管理モード住所種別分類例: 2. ページ管理x86 アーキテクチャ 32 ...

CSS でのフィルタープロパティの使用に関する詳細な説明

フィルター属性は要素の視覚効果を定義しますぼかし画像にガウスぼかしを適用します。 「半径」の値は、ガ...

Linux システムでログを手動でスクロールする方法

ログローテーションは、Linux システムでは非常に一般的な機能です。ログローテーションは、システム...

MySQL での挿入効率のいくつかの例の比較

序文最近、仕事の都合で、約 1000w の大量のデータを MySQL に挿入する必要があり、時間がか...

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

最初のステップはmysqlコンテナを作成することです docker exec -it コンテナID ...

既存のMySQLデータベースの文字セットを統一する方法

序文データベースでは、一部のデータ テーブルとデータは latin1 であり、一部のデータ テーブル...