Vue の this.$router と this.$route の違いと push() メソッド

Vue の this.$router と this.$route の違いと push() メソッド

公式文書には次のように記されている。

ルーターを挿入することで、どのコンポーネントでも this.$router を通じてルーターにアクセスでき、また this.$route を通じて現在のルートにアクセスすることもできます。

それは次のように理解できます。

this.$router は、多くのプロパティとオブジェクト (履歴オブジェクトなど) を含むグローバル ルーター オブジェクトと同等です。どのページでも、push()、replace()、go() などのメソッドを呼び出すことができます。

this.$route は現在のルート オブジェクトを表します。各ルートにはルート オブジェクトがあり、これは対応する名前、パス、パラメータ、クエリ、その他の属性を取得できるローカル オブジェクトです。

push() メソッドについて:

別の URL に移動するには、router.push メソッドを使用します。このメソッドは履歴スタックに新しいレコードを追加するため、ユーザーがブラウザの戻るボタンをクリックすると、前の URL に戻ります。

<router-link> をクリックすると、このメソッドが内部的に呼び出されるため、<router-link :to="..."> をクリックすると router.push(...) を呼び出すのと同じになります。

push() メソッド呼び出し:

    // 文字列 this.$router.push('home')
 
    //オブジェクト this.$router.push({path:'home'})
 
    //名前付きルート this.$router.push({name:'user', params:{userId: '123'}})
 
    //クエリパラメータを使用すると、/register?plan=private になります。
    this.$router.push({path:'register', query:{plan:private}})

注: パスが指定されている場合、パラメータは無視されますが、上記の例のクエリの場合はそうではありません。代わりに、ルート名を指定するか、次の例に示すようにパラメータ付きの完全パスを記述する必要があります。

    定数ユーザーID = '123';
 
    this.$router.push({path:`/user/${userId}`}); //->/user/123
 
    this.$router.push({name:'user', params:{userId}}); //->/user/123
 
    //ここでのパラメータは無効です this.$router.push({path:'/user', params:{userId}}); //->/user

同じルールが router-link コンポーネントの to プロパティにも適用されます。

要約:

params はパラメータを渡すために使用されます。push では、params はルートを導入するために name のみを使用できるため、path:'/xxx' ではなく name:'xxx' のみを使用できます。ここで path が記述されている場合、パラメータを受け取るページは未定義になります。

ルーティングパラメータの受け渡し方法:

1. 完全なパスを手書きします。

    this.$router.push({path: `/user/${userId}`});

パラメータを取得: this.$route.params.userId

2. パラメータを渡します:

    this.$router.push({name:'user', params:{userId: '123'}});

パラメータを取得: this.$route.params.userId

URL 形式: パラメータなしの URL、http:localhost:8080/#/user

3. クエリを使用して以下を渡します。

    this.$router.push({path:'/user', query:{userId: '123'}});

パラメータを取得: this.$route.query.userId

URL 形式: パラメータ付き URL、http:localhost:8080/#/user?userId=123

簡単に言うと、query は get リクエストに相当し、ページがジャンプしたときにアドレスバーにリクエストパラメータが表示されます。params は post リクエストに相当し、パラメータはアドレスバーに表示されません。

/ で始まるネストされたパスはルート パスとして扱われることに注意してください。 これにより、ネストされたパスを設定しなくても、ネストされたコンポーネントを活用できるようになります。

要約する

これで、Vue の this.$router と this.$route の違いと push() メソッドについての説明は終了です。Vue の this.$router と this.$route の違いについてさらに詳しく知りたい方は、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続きご覧ください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • vue.jsのthis.$router.pushが無効である問題を解決する
  • vue3.0 で this.$router.replace({ path: ''/''}) が更新されても効果がない問題について
  • Vue で this.$router.push のパラメータを取得する方法
  • Vue.js this.$router.push は params パラメータを取得できません
  • Vue this.$router.push(parameter) はページジャンプ操作を実装します

<<:  Linuxはscpコマンドを使用してファイルをローカルコンピュータにコピーし、ローカルファイルをリモートサーバーにコピーします。

>>:  mysql8.0.0 winx64.zip 解凍バージョンのインストールと設定のチュートリアル

推薦する

Javascript サンプル プロジェクトでの虫眼鏡効果の実装プロセス

目次序文事例: JD.com の虫眼鏡効果の模倣オフセットシリーズクライアントシリーズスクロールシリ...

Nginxドメイン名転送のhttpsアクセスの実装

事前に一言:突然、複数のドメイン名のアクセスを https に転送するというタスクを受け取りました。...

MySQL データベースは SQL ステートメントを知っている必要があります (拡張バージョン)

拡張版です。質問とSQL文は以下の通りです。ユーザー テーブルを作成し、id、name、gender...

CSS の画像パスの問題に関する議論 (同じパッケージ/異なるパッケージ)

CSS ファイルでは、背景を使用する、つまり背景画像を追加する必要がある場合があります。これは通常、...

JS オブジェクト配列の重複排除のための 3 つの方法の例と比較

目次1. 重複排除前後のデータの比較2. 使い方1. フィルターとマップを使用する2. 削減を使用す...

CSSアニメーション効果アニメーションの一般的なスタイル

アニメーションアニメーションを定義します。 /*アニメーションの各ステップで実行されるアクションを定...

Vue命令の動作原理と実装方法

Vue の紹介現在のビッグフロントエンドの時代は、混乱と衝突の時代です。世界は多くの派閥に分かれてお...

Windows Server 2008R2、2012、2016、2019 の違い

目次共通バージョンの紹介共通バージョンのダウンロードアドレスとインストール以下に簡単な違いを示します...

ローカル yum ソースの設定、国内 yum ソースの設定、epel ソースの設定を行う Linux の手順

1. ローカルyumソースを設定する1. ISOイメージをマウントする マウント -o loop /...

JavaScript を学ぶときに知っておくべき 3 つのヒント

目次1. 魔法の拡張演算子1. 配列をコピーする2. 配列を結合する3. オブジェクトを展開する2....

LinuxにNginxを素早くインストールする方法

目次nginxとは1. 必要な依存関係をダウンロードする2. nginxの圧縮パッケージをダウンロー...

MySQL 権限とデータベース設計のケーススタディ

権限とデータベース設計ユーザー管理SQLyogを使用してユーザーを作成し、権限を付与する基本コマンド...

MySQLのカバーインデックスに関する知識ポイントのまとめ

インデックスにクエリする必要があるすべてのフィールドの値が含まれている(またはカバーしている)場合、...

フロートをクリアするための CSS メソッドの概要

フロートはWebページのレイアウトでよく使用されますが、フローティングブロックレベル要素は標準のドキ...

Apache Bench で Web ストレス テストを実装する方法

1. Apache Benchの紹介ApacheBench は、Apache サーバーに付属する W...