學習和分享關于 Vue.js 的路由(vue-router)

學習和分享關于 Vue.js 的路由(vue-router)是一個非常有價值的主題,因為路由是構建單頁應用程序(SPA)的核心部分。本文將介紹 Vue.js 路由的基本概念和實現,并展示一個典型的項目目錄結構。

目錄

    • Vue.js 路由簡介
    • 目錄結構
      • 關鍵文件和文件夾
    • 實現基本的路由
      • 1. 安裝 Vue Router
      • 2. 配置路由
      • 3. 創建視圖組件
      • 4. 修改 `main.js`
      • 5. 更新根組件 `App.vue`
      • 6. 啟動開發服務器

Vue.js 路由簡介

Vue Router 是 Vue.js 官方的路由管理器,允許我們在 Vue 應用中實現客戶端路由。它使我們可以創建多個頁面或視圖,并在用戶導航時保持單頁應用程序的感覺。

目錄結構

一個典型的 Vue.js 項目目錄結構(包括 Vue Router)如下所示:

my-vue-app/
├── node_modules/
├── public/
│   ├── index.html
│   └── ...
├── src/
│   ├── assets/
│   ├── components/
│   │   ├── Home.vue
│   │   ├── About.vue
│   │   └── ...
│   ├── router/
│   │   └── index.js
│   ├── views/
│   │   ├── HomeView.vue
│   │   ├── AboutView.vue
│   │   └── ...
│   ├── App.vue
│   ├── main.js
│   └── ...
├── .gitignore
├── babel.config.js
├── package.json
├── README.md
└── vue.config.js

關鍵文件和文件夾

  • public/:包含靜態文件,如 index.html
  • src/:包含源代碼。
    • assets/:存放靜態資源(如圖片、字體等)。
    • components/:存放 Vue 組件。
    • router/:存放路由配置文件。
      • index.js:定義路由和路由規則。
    • views/:存放視圖組件(通常是頁面級組件)。
    • App.vue:根組件。
    • main.js:入口文件,初始化 Vue 實例并掛載到 DOM。

實現基本的路由

下面是實現基本路由的步驟:

1. 安裝 Vue Router

首先,需要安裝 Vue Router:

npm install vue-router

2. 配置路由

創建并配置路由文件 src/router/index.js

import Vue from 'vue';
import VueRouter from 'vue-router';
import HomeView from '../views/HomeView.vue';
import AboutView from '../views/AboutView.vue';Vue.use(VueRouter);const routes = [{path: '/',name: 'Home',component: HomeView},{path: '/about',name: 'About',component: AboutView}
];const router = new VueRouter({mode: 'history',base: process.env.BASE_URL,routes
});export default router;

3. 創建視圖組件

src/views/ 目錄下創建視圖組件 HomeView.vueAboutView.vue

HomeView.vue

<template><div><h1>Home Page</h1><p>Welcome to the home page.</p></div>
</template><script>
export default {name: 'HomeView'
};
</script><style scoped>
/* Add your styles here */
</style>

AboutView.vue

<template><div><h1>About Page</h1><p>This is the about page.</p></div>
</template><script>
export default {name: 'AboutView'
};
</script><style scoped>
/* Add your styles here */
</style>

4. 修改 main.js

src/main.js 中引入并使用路由:

import Vue from 'vue';
import App from './App.vue';
import router from './router';Vue.config.productionTip = false;new Vue({router,render: h => h(App)
}).$mount('#app');

5. 更新根組件 App.vue

修改 src/App.vue 以包含路由視圖和導航鏈接:

<template><div id="app"><nav><router-link to="/">Home</router-link><router-link to="/about">About</router-link></nav><router-view/></div>
</template><script>
export default {name: 'App'
};
</script><style>
/* Add your styles here */
</style>

6. 啟動開發服務器

最后,啟動開發服務器并查看效果:

npm run serve

打開瀏覽器訪問 http://localhost:8080,你應該能夠看到首頁和關于頁面,并可以通過導航鏈接在它們之間切換。


通過這些步驟,你已經創建了一個包含 Vue Router 的基本 Vue.js 應用程序。你可以根據需要添加更多的路由和組件,以構建更加復雜和功能豐富的應用。希望這篇文章能幫助你快速入門并分享 Vue.js 路由的知識。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/15934.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/15934.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/15934.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【代碼隨想錄訓練營】【Day 29】【回溯-3】| Leetcode 39, 41, 131

【代碼隨想錄訓練營】【Day 29】【回溯-3】| Leetcode 39&#xff0c; 41&#xff0c; 131 需強化知識點 startInex作用&#xff1a;一是處理是否可以有重復值&#xff0c;二是實現縱向遍歷&#xff08;不能沒有&#xff09;去重要在數組有序的前提下進行分割問題 題目 39.…

工業控制2D組態界面,丑是丑了點,但非常實用。

工業控制的2D組態界面是用于監控和控制工業過程的界面。它通常具有以下特征&#xff1a; 實時數據顯示&#xff1a;2D組態界面能夠實時顯示傳感器和設備的數據&#xff0c;如溫度、壓力、流量等。這些數據以圖表、儀表盤、數字顯示等形式呈現&#xff0c;使操作人員能夠實時了解…

Android:使用Kotlin搭建MVVM架構模式

一、簡介Android MVVM架構模式 MVVM全稱&#xff1a;Model、View、ViewModel&#xff1b; Model&#xff1a;負責數據的請求、解析、過濾等數據層操作&#xff0c;其中Repository: 提供數據的 API&#xff08;從本地或者網絡&#xff09;。View&#xff1a;負責視圖部分展示Vie…

Spring (18)什么是JdbcTemplate

JdbcTemplate 是 Spring 框架提供的一個主要的類&#xff0c;旨在簡化傳統 JDBC 的使用。它處理了諸如連接管理、異常處理等繁瑣的低級任務&#xff0c;讓開發者可以更專注于執行 SQL 語句和處理結果。JdbcTemplate 屬于 Spring JDBC 模塊&#xff08;spring-jdbc&#xff09;&…

每日力扣刷題day05(小白簡單題)

文章目錄 2024.5.26&#xff08;5題&#xff09;1446.連續字符題解一題解二 2824.統計和小于目標的下標對數目題解一題解二 1768.交替合并字符串題解一題解二題解三 796.旋轉字符串題解一題解二 1304.和為零的 N 個不同整數題解一題解二 2024.5.26&#xff08;5題&#xff09; …

快速冪求逆元與逆元

我上一篇博客鏈接寫的是多個數求乘法逆元而快速冪求逆元用于單個數求乘法逆元 逆元是對分數取模用的 對于除法取模不成立&#xff0c;即(a/b)%p≠(a%p/b%p)%p。求逆元的思路&#xff1a;(一般ACM的題目都是對1e97這種素數取模&#xff0c;所以gcd(a,p)1)a*b1(mod p) > b1/a…

[Algorithm][動態規劃][簡單多狀態DP問題][按摩師][打家劫舍Ⅱ][刪除并獲得點數][粉刷房子]詳細講解

目錄 1.按摩師1.題目鏈接2.算法思路詳解3.代碼實現 2.打家劫舍 II1.題目鏈接2.算法思路詳解3.代碼實現 3.刪除并獲得點數1.題目鏈接2.算法思路詳解3.代碼實現 4.粉刷房子1.題目鏈接2.算法思路詳解3.代碼實現 1.按摩師 1.題目鏈接 按摩師 2.算法思路詳解 思路&#xff1a; 確…

大模型提示詞Prompt學習

引言 關于chatGPT的Prompt Engineer&#xff0c;大家肯定耳朵都聽起繭了。但是它的來由&#xff1f;&#xff0c;怎么能用好&#xff1f;很多人可能并不覺得并不是一個問題&#xff0c;或者說認定是一個很快會過時的概念。但其實也不能說得非常清楚&#xff08;因為覺得沒必要深…

Redis第18講——Redis和Redission實現延遲消息

即使不是做電商業務的同學&#xff0c;也一定知道訂單超時關閉這種業務場景&#xff0c;這個場景大致就是用戶下單后&#xff0c;如果在一定時間內未支付&#xff08;比如15分鐘、半小時&#xff09;&#xff0c;那么系統就會把這筆訂單給關閉掉。這個功能實現的方式有很多種&a…

unity開發Hololens 制作滑動框

一定要做到最后一步&#xff0c;才會有效果 1、創建空物體 ,并添加組件 創建空物體 命名ScrollingObjectCollection&#xff0c; 添加組件如下圖 下面是各個組件展開的內容 2、在ScrollingObjectCollection 下面創建兩個空物體&#xff0c;分別命名Container、Clipping…

運籌說 第115期 | 排隊論經典例題講解

通過前幾期的學習&#xff0c;我們已經學會了排隊論的基本概念、生滅過程和Poisson過程&#xff0c;等待制排隊模型、混合制排隊模型、其他排隊模型以及排隊系統優的定義與相關求解方法。在實際工作中&#xff0c;我們能發現排隊論在經濟管理中有著許多應用&#xff0c;本期小編…

大數據量上傳FTP

背景 筆者有一個需求是把將近一億條數據上傳到FTP服務器中&#xff0c;這些數據目前是存儲在mysql中&#xff0c;是通過關聯幾張表查詢出來的&#xff0c;查詢出來的數據結果集一共是6個字段。要求傳輸的時候拆分成一個個小文件&#xff0c;每個文件大小不能超過500M。我的測試…

FuTalk設計周刊-Vol.052

#AI漫談 熱點捕手 1.ChatGPT 大更新&#xff01;GPT-4 開始又變聰明了 OpenAI 官方宣布&#xff0c;新版 GPT-4 Turbo 今天開始向所有付費 ChatGPT 用戶開放。 鏈接https://www.pconline.com.cn/focus/1733/17330089.html 2.刷爆多模態任務榜單&#xff01;賈佳亞團隊Mini-G…

Linux下環境變量配置出錯導致基礎命令使用不了的問題解決

問題&#xff1a; 當配置環境變量&#xff1a; echo export PATH/home/ubuntu/.local/lib/python3.8/site-packages :$PATH >> ~/.bashrc 執行生效命令 source ~/.bashrc 出現所有的基礎操作命令&#xff1a;ls vim都使用不了 解決方式&#xff1a; 1&#xff09…

21.2zabbix低級自動發現-mysql多實例

配置mysql多實例 注釋&#xff1a;自動發現&#xff1a;創建監控主機&#xff1b;低級自動發現&#xff1a;創建監控項 mysql單實例是直接yum安裝&#xff0c;開啟mysql多實例 準備配置文件 #mysql3307實例 cp /etc/my.cnf /etc/my3307.cnf vim /etc/my3307.cnf [mysqld] dat…

lazarus-IDE 可以開發 Node.js 嗎?

Lazarus IDE 本身不是用來開發 Node.js 應用程序的工具&#xff0c;因為它是一個用于開發跨平臺應用程序的環境&#xff0c;類似于 C Builder 或 Delphi。Node.js 是一個基于 JavaScript 的運行時環境&#xff0c;通常使用 V8 引擎&#xff0c;用于構建異步、事件驅動的服務器端…

產品經理-流程圖結構圖(四)

1. 流程圖 1.1 概念 為了達到特定的目標而進行的一系列有邏輯性的操作步驟&#xff0c;由兩個及以上的步驟&#xff0c;完成一個完整的行為的過程&#xff0c;可稱之為流程 1.2 產品經理為什么需要繪制流程圖&#xff1f; 保證產品的使用邏輯合理順暢向項目組其他成員清晰的…

代碼隨想錄算法訓練營Day4|24. 兩兩交換鏈表中的節點、19.刪除鏈表的倒數第N個節點、 142.環形鏈表II、面試題 02.07. 鏈表相交

24. 兩兩交換鏈表中的節點 這道題的關鍵在于: 1、在置換兩個節點的時候&#xff0c;當前節點需要在這倆節點之前一個節點。并且要提前保存cur.next以及cur.next.next。 2、每次置換完一組節點&#xff0c;cur cur.next.next 3、判斷結束的標志&#xff1a;奇數個節點&#xf…

如何禁止U盤拷貝文件|禁止U盤使用的軟件有哪些

禁止U盤拷貝文件的方法有很多&#xff0c;比如使用注冊表、組策略編輯器等&#xff0c;但這些方法都適合個人&#xff0c;不適合企業&#xff0c;因為企業需要對下屬多臺電腦進行遠程管控&#xff0c;需要方便、省時、省力的方法。目前來說&#xff0c;最好的方法就是使用第三方…

Unity websocket客戶端

&#x1f3c6; 個人愚見&#xff0c;沒事寫寫筆記 &#x1f3c6;《博客內容》&#xff1a;Unity3D開發內容 &#x1f3c6;&#x1f389;歡迎 &#x1f44d;點贊?評論?收藏 &#x1f50e;目標&#xff1a;服務器和客戶端可以實時的傳輸信息 ??實現目標&#xff1a; 使用的w…