検索
ホームページウェブフロントエンドjsチュートリアルVueモバイル端末ルーティング切り替え事例分析

今回は、Vue モバイル ルーティング スイッチングの事例分析をお届けします。Vue モバイル ルーティング スイッチングの 注意事項 は何ですか? 実際のケースを見てみましょう。

その中で最も重要なのは、次の 2 つの問題です:

ブラウザのナビゲーション バーの切り替え

スライドして IOS をオンにすると、2 つのページ遷移アニメーションが表示され、1 つはスライド単独で切り替わり、その後トリガーされます。トランジションアニメーションを設定します。

上記の 2 つの質問を除き、残りの操作はページ内で設定でき、基本的に制御可能です。主に上記2つの問題を解決します。

実際に書かれた効果を確認できます: オンラインデモ

1. ブラウザのナビゲーションバーを切り替える

過去の記録を記録して、進むか戻るかを比較して判断します

次の例

Aページ-> ページ B-> ページ C

ページ A からページ B、そしてページ C に移動すると、3 つの履歴レコードが存在します

配列を使用して表します: ['/a' , '/b' , '/c']

その後、ブラウザのナビゲーション バーの戻るボタンをクリックすると、ページ B に戻ります。

この時点では、ページ B が存在するかどうかを判断するだけです。存在することは、私が戻るボタンをクリックしたことを証明します。

その後、戻ったらすぐにブラウザの進むボタンをクリックできます。現時点で前進しているかどうかをどのように判断するのでしょうか?

これならできます。

ページ B に戻っても、履歴レコードには 3 つのパス ['/a'、'/b'、'/c'] が保存されていますよね

ページ B の背後にあるパスは削除できるので、今すぐそれは [ '/a', '/b'] です。
ページ A に戻る場合、保存するパスは ['/a'] です。

進むボタンをクリックしている限り、次のページに進みましょう保存されたパスを探してくださいね? パスが見つからないので、前方判定は完了です。

上記は通常の状況です。
しかし、いくつかのページを繰り返し入力するとどうなるでしょうか。

次の状況と同じです

A ページ-> 次に、一歩下がってページ B に到達しました

この時点で、最初の B ページの後ろのパスを削除するべきか、それとも後ろのパスを削除すべきかという問題が生じます。 2 番目の B ページ

まず 2 番目のページを削除してみましょう。ページ B のパス、その後も保存するパスは ['/a', '/b', '/c', '/b'] です。

1. この時点では、上記の通常の状況のロジックに従って動作します。

見つからない場合は、保存されたパスに移動します。証拠が見つかったら戻ります。

結果は明らかです。最初の C ページが見つかったので、戻るとカウントされますが、実際には、それをクリックすると進むことになります

2. 次に、最初の B の背後にあるパスを削除してみます。保存されたパスは: ['/a', '/b'],

そして、戻るボタンをクリックすると、実際に C ページに入ります。次のフローチャートが表示されます

この時、ここで戻るボタンをクリックするとページCに移動しますが、保存されたパスの`'/c'`は私が削除しているので、前方と判断されます。

1. 重複するページ パスを除外したほうが良いと思いませんか? 実際、同じことです

5 つのページ パスがあり、2 つの重複を除外すると、3 つのページ パスのみになります

その後、4 番目のパスに後退したときに見つからなかった場合は、次の 2 ページが前進としてカウントされます。

現在の観点から見ると、最良の方法は各ページを記録することですが、各ページは異なる必要があります

その後、URLにランダムな
文字列を置くことができます

コードの実装:

// 当没有key的时候会进入两次 beforeEach,我们只需保存带key的就行
const updateNavigations = (to) => {
 if (to.query[pathKey]) {
  store.commit('UPDATE_NAVIGATIONS', {path: to.fullPath})
 }
}

router.beforeEach((to, from, next) => {
 let toIndex = store.state.navigations.findIndex(path => path === to.fullPath)
 if (toIndex >= 0) { // 存在该路径
  let len = store.state.navigations.length-1
  if (toIndex === len) { // 当前路径是最后一条,证明是同一个页面
   console.log('refresh') 
  } else { // 后退
   store.commit('UPDATE_ROUTER_DIRECTION', { routerDirection: 'back' }) // 后退标志
   store.commit('DELETE_NAVIGATION', { index: toIndex }) // 删除当前路径后面的路径
  }
 }else{ // 不存在该路径
  store.commit('UPDATE_ROUTER_DIRECTION', { routerDirection: 'forward' }) // 前进标志
  updateNavigations(to) // 保存该连接
 }

 const query = { ...to.query }
 // 存在就直接next, 防止死循环
 if (!query['APP_KEY']) { // 不存在添加key ,再次 next
  query['APP_KEY'] = Math.random().toString(16).substring(2)
  next({ path: to.path, query})
 }else{
  next()
 }
})


上記のコードを使用すると、APP_KEY のランダムな文字列を URL に追加できるため、保存するパスに同じページがあったとしても、実際には異なるものになります。ロジックは正常に実行できます

上記は基本的にブラウザのナビゲーションバーの問題を解決します

2. IOSでのスライド切り替え

IOSのWebページでは、次の場合でも、左右にスライドして切り替えることができます。トランジションアニメーションを行っていません。

この時問題が発生します。

まだABCページです

A -> B -> C

Cページまで行って、左にスライドするとBページに入りますが、このままです。 beforeEach フック関数に入るまでの時間、上記のロジックが実行されます。

これにより、遷移アニメーションがトリガーされます。 2 つの切り替えが実行されていることがわかります。

そこで、iOSの左スワイプを修正してアニメーションを再度実行する方法をインターネットで見つけました#2259

コードは次のようなものです

let touchEndTime = Date.now()

window.addEventListener('touchend', () => {
 touchEndTime = Date.now()
})

router.beforeEach((to, from, next) => {
 if ((Date.now() - touchEndTime) < 377) { // ios滑动切换
  store.commit(&#39;UPDATE_ROUTER_DIRECTION&#39;, { routerDirection: &#39;&#39; })
 }
})


上記もわかりやすいです。つまり、指が最終的に画面から離れる瞬間を取得し、次に指が画面から離れる最後の瞬間と、直前のそれぞれの瞬間との違いを比較します。指が画面から離れると、前に私たち自身のトランジションが発生します。IOS のスライド切り替えであっても、それぞれが 337 未満です

これにより、IOS のスライド切り替えの問題が解決されます。

しかし、IOSは右にスライドして切り替えた場合、指が画面から離れる瞬間を監視できないので(ゴーストが何かはわかりません)、IOSが右にスライドして切り替えた場合は上記のように判断できません。


これについても今のところ解決策は見つかっていませんが、IOSで左にスワイプして戻るスイッチを解決することしかできません。

基本的に、最も面倒な点は上記の 2 点です。残りは

イベントを監視することで設定できます。これはまったく難しいことではありません

オンライン DEMO デモ

この記事の事例を読んだことがあるかと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。

推奨書籍:

jQuery クラス名セレクター (.class) の使用方法の詳細な説明

vue の動的バインド コンポーネントのサブ親コンポーネント マルチフォーム検証の実装手順

以上がVueモバイル端末ルーティング切り替え事例分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Python编程解析百度地图API文档中的坐标转换功能Python编程解析百度地图API文档中的坐标转换功能Aug 01, 2023 am 08:57 AM

Python编程解析百度地图API文档中的坐标转换功能导读:随着互联网的快速发展,地图定位功能已经成为现代人生活中不可或缺的一部分。而百度地图作为国内最受欢迎的地图服务之一,提供了一系列的API供开发者使用。本文将通过Python编程,解析百度地图API文档中的坐标转换功能,并给出相应的代码示例。一、引言在开发中,我们有时会涉及到坐标的转换问题。百度地图AP

Python解析XML中的特殊字符和转义序列Python解析XML中的特殊字符和转义序列Aug 08, 2023 pm 12:46 PM

Python解析XML中的特殊字符和转义序列XML(eXtensibleMarkupLanguage)是一种常用的数据交换格式,用于在不同系统之间传输和存储数据。在处理XML文件时,经常会遇到包含特殊字符和转义序列的情况,这可能会导致解析错误或者误解数据。因此,在使用Python解析XML文件时,我们需要了解如何处理这些特殊字符和转义序列。一、特殊字符和

使用Python解析SOAP消息使用Python解析SOAP消息Aug 08, 2023 am 09:27 AM

使用Python解析SOAP消息SOAP(SimpleObjectAccessProtocol)是一种基于XML的远程过程调用(RPC)协议,用于在网络上不同的应用程序之间进行通信。Python提供了许多库和工具来处理SOAP消息,其中最常用的是suds库。suds是Python的一个SOAP客户端库,可以用于解析和生成SOAP消息。它提供了一种简单而

PHP8.0中的XML解析库PHP8.0中的XML解析库May 14, 2023 am 08:19 AM

随着PHP8.0的发布,许多新特性都被引入和更新了,其中包括XML解析库。PHP8.0中的XML解析库提供了更快的解析速度和更好的可读性,这对于PHP开发者来说是一个重要的提升。在本文中,我们将探讨PHP8.0中的XML解析库的新特性以及如何使用它。什么是XML解析库?XML解析库是一种软件库,用于解析和处理XML文档。XML是一种用于将数据存储为结构化文档

使用Python解析带有命名空间的XML文档使用Python解析带有命名空间的XML文档Aug 09, 2023 pm 04:25 PM

使用Python解析带有命名空间的XML文档XML是一种常用的数据交换格式,能够适应各种应用场景。在处理XML文档时,有时会遇到带有命名空间(namespace)的情况。命名空间可以防止不同XML文档中元素名的冲突,提高了XML的灵活性和可扩展性。本文将介绍如何使用Python解析带有命名空间的XML文档,并给出相应的代码示例。首先,我们需要导入xml.et

PHP 爬虫实战之获取网页源码和内容解析PHP 爬虫实战之获取网页源码和内容解析Jun 13, 2023 am 10:46 AM

PHP爬虫是一种自动化获取网页信息的程序,它可以获取网页代码、抓取数据并存储到本地或数据库中。使用爬虫可以快速获取大量的数据,为后续的数据分析和处理提供巨大的帮助。本文将介绍如何使用PHP实现一个简单的爬虫,以获取网页源码和内容解析。一、获取网页源码在开始之前,我们应该先了解一下HTTP协议和HTML的基本结构。HTTP是HyperText

PHP中的单点登录(SSO)鉴权方法解析PHP中的单点登录(SSO)鉴权方法解析Aug 08, 2023 am 09:21 AM

PHP中的单点登录(SSO)鉴权方法解析引言:随着互联网的发展,用户通常要同时访问多个网站进行各种操作。为了提高用户体验,单点登录(SingleSign-On,简称SSO)应运而生。本文将探讨PHP中的SSO鉴权方法,并提供相应的代码示例。一、什么是单点登录(SSO)?单点登录(SSO)是一种集中化认证的方法,在多个应用系统中,用户只需要登录一次,就能访问

PHP中的HTTP Basic鉴权方法解析及应用PHP中的HTTP Basic鉴权方法解析及应用Aug 06, 2023 am 08:16 AM

PHP中的HTTPBasic鉴权方法解析及应用HTTPBasic鉴权是一种简单但常用的身份验证方法,它通过在HTTP请求头中添加用户名和密码的Base64编码字符串进行身份验证。本文将介绍HTTPBasic鉴权的原理和使用方法,并提供PHP代码示例供读者参考。一、HTTPBasic鉴权原理HTTPBasic鉴权的原理非常简单,当客户端发送一个请求时

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境