中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue.js中怎么使用嵌套路由

發布時間:2022-04-25 17:03:35 來源:億速云 閱讀:147 作者:zzz 欄目:大數據

本文小編為大家詳細介紹“Vue.js中怎么使用嵌套路由”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Vue.js中怎么使用嵌套路由”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

用 Vue CLI 進行設置

如果尚未安裝,請運行以下命令全局安裝 Vue CLI:

$ npm install -g @vue/cli

或者

$ yarn global add @vue/cli

現在你能從命令行運行 vue 命令了。讓我們創建一個名為 alligator-nest 的 Vue 應用:

$ vue create alligator-nest

在提示符下選擇默認預設(按 Enter 鍵)。之后,運行以下命令:

$ npm install vue-router

然后,在你選擇的編輯器中打開 alligator-nest 目錄。

基本代碼

以下 CSS 將幫助我們為 UI 定位元素。將其作為樣式表文件添加到 public/ 文件夾中,并在 public/index.html  中引用它。為此,我們將使用 CSS grid:

grid.css:

.row1 {   grid-row-start: 1;   grid-row-end: 2; }  .row12 {   grid-row-start: 1;   grid-row-end: 3; }  .row123 {   grid-row-start: 1;   grid-row-end: 4; }  .row2 {   grid-row-start: 2;   grid-row-end: 3; }  .row23 {   grid-row-start: 2;   grid-row-end: 4; }  .row3 {   grid-row-start: 3;   grid-row-end: 4; }  .col1 {   grid-column-start: 1;   grid-column-end: 2; }  .col12 {   grid-column-start: 1;   grid-column-end: 3; }  .col123 {   grid-column-start: 1;   grid-column-end: 4; }  .col1234 {   grid-column-start: 1;   grid-column-end: 5; }  .col2 {   grid-column-start: 2;   grid-column-end: 3; }  .col23 {   grid-column-start: 2;   grid-column-end: 4; }  .col234 {   grid-column-start: 2;   grid-column-end: 5; }  .col3 {   grid-column-start: 3;   grid-column-end: 4; }  .col34 {   grid-column-start: 3;   grid-column-end: 5; }  .col4 {   grid-column-start: 4;   grid-column-end: 5; }

接下來,讓我們對 vue-cli 添加的默認文件進行一些更改。

從 src/components 文件夾中刪除 HelloWorld.vue,并從 src/App.vue 中刪除所有與其相關的東西。對 App.vue  中的 HTML 標記和 CSS 樣式進行以下修改。

<template>   <div id="app">     <h2 class="row1 col12">Alligator Nest</h2>     <a class="row1 col3">Travels</a>     <a class="row1 col4">About</a>     <div class="row2 col234"></div>   </div> </template> html, body {   height: 100vh;   width: 100vw;   padding: 0;   margin: 0; }  #app {   font-family: Avenir, Helvetica, Arial, sans-serif;   -webkit-font-smoothing: antialiased;   -moz-osx-font-smoothing: grayscale;   color: #2c3e50;   padding: 2%;   height: 100%;   display: grid;   grid-template-rows: 20% 80%;   grid-template-columns: 25% 25% 25% 25%; }

如果你在項目的根目錄中運行 npm run serve,則可以將鼠標懸停在瀏覽器中的 localhost:8080 上,并查看框架布局。那些  display:grid 屬性很有用!現在我們可以開始創建路由了。

輸入 Vue 路由

在 /components 文件夾中創建一個名為 AboutPage.vue 的組件。它看起來像這樣:

<template>   <div>     <h3>About</h3>     <p>Alligators were around during the time of the dinosaurs.</p>   </div> </template>  <script>   export default {     name: 'AboutPage',   } </script>  <style scoped>    </style>

現在我們的 main.js 文件需要 /about 路由。它看起來像這樣。

import VueRouter from 'vue-router'; import Vue from 'vue'; import App from './App.vue';  Vue.config.productionTip = false;  import VueRouter from 'vue-router'; Vue.use(VueRouter);  import AboutPage from './components/AboutPage.vue';  const routes = [   { path: '/about', component: AboutPage }, ]  const router = new VueRouter({   routes })  new Vue({   render: h => h(App),   router }).$mount('#app');

最后,讓我們回到 App.vue,并將 “About” 的錨標記更改為屬性為 to="/about"的

現在,我們有了一個功能齊全的站點框架,并為 “About” 頁面處理了路由。

我們在此重點介紹路由功能,因此不會在樣式上話費太多時間。盡管如此,我們也要讓Travels 頁面看起來更精致一些。

首先,創建一個 TravelPage,方法與創建 AboutPage 相同。在 main.js 中引用它。

還需要創建以下兩個組件,這些組件最終將嵌套在 TravelPage.vue 中:

TravelAmericaPage.vue

<template>   <div>     <p>Alligators can be found in the American states of Louisiana and Florida.</p>   </div> </template>  <script>   export default {     name: 'TravelAmericaPage'   } </script>  <style scoped> </style>

TravelChinaPage.vue

<template>   <div>     <p>Alligators can be found in China's Yangtze River Valley.</p>   </div> </template>  <script>   export default {     name: 'TravelChinaPage'   } </script>  <style scoped>  </style>

配置嵌套路由

現在,讓我們同時更新 main.js 和 TravelPage.vue,以使用 children 來引用這些嵌套路由。必須將 main.js 更新為對  routes 常量具有以下定義:

const routes = [   {     path: '/travel', component: TravelPage,     children: [       { path: '/travel/america', component: TravelAmericaPage },       { path: '/travel/china', component: TravelChinaPage}     ]   },   {     path: '/about', component: AboutPage   } ];

請注意,子級的嵌套可以無限繼續下去。

并且 TravelPage.vue 可以通過以下方式編寫:

TravelPage.vue:

<template>   <div id="travel">     <h3 class="row1">Travels</h3>     <div class="flex-container row2">       <router-link to="/travel/america">America</router-link>       <router-link to="/travel/china">China</router-link>     </div>     <router-view class="row3"></router-view>   </div> </template>  <script>   export default {     name: 'TravelPage'   } </script>  <style scoped> div {   text-align: center; }  #travel {   display: grid;   grid-template-rows: 20% 40% 40%; }  .flex-container {   display: flex;   justify-content: space-around; } </style>

檢出 localhost:8080,你將看到 Travels 頁面中包含 2 個子頁面!當你單擊任一鏈接時,我們的 URL 也會相應更新。

讀到這里,這篇“Vue.js中怎么使用嵌套路由”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

胶州市| 舟曲县| 揭西县| 襄汾县| 青州市| 芜湖县| 贺兰县| 西丰县| 仲巴县| 博客| 高密市| 澳门| 宁海县| 万山特区| 五台县| 南昌县| 天水市| 临武县| 紫阳县| 纳雍县| 靖边县| 宜宾市| 临邑县| 四子王旗| 苏尼特右旗| 尤溪县| 淮安市| 镇平县| 高淳县| 昌江| 肇庆市| 绥中县| 平凉市| 乾安县| 开阳县| 白山市| 会泽县| 大埔区| 兴城市| 兴国县| 枞阳县|