Layout 和 嵌套路由

回顧一下默認(rèn)項(xiàng)目代碼,App.vue 里在router-view上邊有一行img引入了vue 的logo圖片

如果我們項(xiàng)目足夠的簡(jiǎn)單肥矢,比如只有一種layout,我們大可以在App.vue里就做好布局认臊,
但是我們要做的項(xiàng)目有2種layout扳炬,那么我們可以理解為App.vue 渲染的是整頁,啥也沒有的蝙眶,在這里去渲染那2種layout布局凰萨。

我們先實(shí)現(xiàn)這個(gè)
先刪掉 App.vue 里的 <img src="./assets/logo.png">
還有下邊的樣式,看起來沒啥鳥用械馆,一會(huì)我們自己寫

先定義2個(gè)layout

在src\layouts目錄創(chuàng)建 Login.vue 和 BaseAdmin.vue

// Login.vue

<template>
  <div>login</div>
</template>

// BaseAdmin.vue

<template>
  <div>
    admin
  </div>
</template>

修改router指向它們

這時(shí)我在瀏覽器修改url去訪問報(bào)了404胖眷,應(yīng)該是哪里有問題,這個(gè)對(duì)開發(fā)沒影響的可以暫時(shí)不管霹崎,先讓項(xiàng)目進(jìn)行下去珊搀,空的時(shí)候再研究,先注釋掉 routes 那的mode配置

router的完整代碼

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
import BaseAdmin from '@/layouts/BaseAdmin'
import Login from '@/layouts/Login'

Vue.use(Router)

const MyHelloWorld = {
  template: '<div><my-title title="我是標(biāo)題">我是變的<br>我也是<hr>我還是</my-title><router-link to="/hello">goto hello</router-link></div>'
}

const MyTitle = {
  template: '<div><h1 style="background-color: #ccc"></h1><slot/></div>',
  props: ['title']
}

Vue.component('my-title', MyTitle)

export default new Router({
  // mode: 'history',
  routes: [
    {
      path: '/',
      name: 'MyHelloWorld',
      component: MyHelloWorld
    },
    {
      path: '/admin',
      name: 'BaseAdmin',
      component: BaseAdmin
    },
    {
      path: '/login',
      name: 'Login',
      component: Login
    },
    {
      path: '/hello',
      name: 'HelloWorld',
      component: HelloWorld
    }
  ]
})

這時(shí)我們對(duì)url /#/admin/#/login 訪問去看生效情況尾菇,
然后接下來就是去把這兩個(gè)頁面做的像那么點(diǎn)樣子出來

// Login.vue

<template>
  <div>
    <h1>用戶登陸</h1>
    <form>
      <label>
        用戶名 
        <input name="username" />
      </label>
      <label>
        密碼  
        <input name="password" type="password" />
      </label>
      <p>
        <router-link :to="{name: 'BaseAdmin'}">登陸</router-link>
      </p>
    </form>
  </div>
</template>

點(diǎn)了登陸就可以跳去admin頁境析,先這么寫,一會(huì)再來完善它派诬,不能男女搭配就自己來控制節(jié)奏吧劳淆,
我是習(xí)慣先寫一輪html,再寫一輪css默赂,反復(fù)反復(fù)直到需要花精力去完善一個(gè)具體的功能頁面沛鸵,

先按照我的習(xí)慣來擼一輪html

// BaseAdmin.vue 在baseAdmin里再放一個(gè)router-view來做嵌套路由

<template>
  <div>
    <header>
      logo
    </header>
    <section>
      <aside>左側(cè)菜單</aside>
      <section>
        <router-view></router-view>
      </section>
    </section>
  </div>
</template>

修改路由給admin增加children

    {
      path: '/admin',
      name: 'BaseAdmin',
      component: BaseAdmin,
      children: [
        {
          path: '',
          name: 'adminHello',
          component: MyHelloWorld,
        }
      ]
    },

頁面看起來這個(gè)樣子,先不考慮排版缆八,查看一下dom結(jié)構(gòu)是我們想要的樣子

image

我們來排下版曲掰,讓頁面看起來更直觀

<template>
  <div>
    <header>
      logo
    </header>
    <aside>左側(cè)菜單</aside>
    <section class="main">
      <router-view></router-view>
    </section>
  </div>
</template>

<style scoped>
header {
  background-color:#123;
  height: 50px;
  line-height: 50px;
  position:absolute;
  top:0;
  left:0;
  right:0;
  color:#fff;
}
.main {
  position: absolute;
  left: 200px;
  top: 50px;
  right: 0;
  bottom: 0;
  overflow: hidden;  
}
aside {
  width:200px;
  background-color: #234;
  color: #fff;
  position:absolute;
  top:50px;
  left:0;
  bottom:0;
}
</style>

image

是不是有那么點(diǎn)樣子了,接下來我們新增加幾個(gè)導(dǎo)航鏈接

<template>
  <div>
    <header>
      logo
    </header>
    <aside>左側(cè)菜單
      <ul>
        <li>
          <router-link :to="{name:'adminDaohang1'}">導(dǎo)航菜單一</router-link>
        </li>
        <li>
          <router-link :to="{name:'adminDaohang2'}">導(dǎo)航菜單二</router-link>
        </li>
      </ul>
    </aside>
    <section class="main">
      <router-view></router-view>
    </section>
  </div>
</template>

修改路由奈辰,還記得之前定義的MyTitle組件么栏妖,現(xiàn)在我們要再路由里給它傳值

    {
      path: '/admin',
      name: 'BaseAdmin',
      component: BaseAdmin,
      children: [
        {
          path: '',
          name: 'adminHello',
          component: MyHelloWorld
        },
        {
          path: 'daohang1',
          name: 'adminDaohang1',
          component: MyTitle,
          props: {title: "導(dǎo)航1"}
        },
        {
          path: 'daohang2',
          name: 'adminDaohang2',
          component: MyTitle,
          props: {title: "導(dǎo)航2"}
        }
      ]
    },

在瀏覽器里測(cè)試一下效果吧。

最后別忘了提交代碼到git倉庫

$ git add .
$ git commit -a -m "chapter5"

這次我們還有給代碼打個(gè)tag奖恰,這樣以后我們可以很方便的穿越到這一節(jié)的代碼狀態(tài)

$ git tag chapter5
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末吊趾,一起剝皮案震驚了整個(gè)濱河市宛裕,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌论泛,老刑警劉巖续滋,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異孵奶,居然都是意外死亡疲酌,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門了袁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來朗恳,“玉大人,你說我怎么就攤上這事载绿≈嘟耄” “怎么了?”我有些...
    開封第一講書人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵崭庸,是天一觀的道長(zhǎng)怀浆。 經(jīng)常有香客問我,道長(zhǎng)怕享,這世上最難降的妖魔是什么执赡? 我笑而不...
    開封第一講書人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮函筋,結(jié)果婚禮上沙合,老公的妹妹穿的比我還像新娘。我一直安慰自己跌帐,他們只是感情好首懈,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著谨敛,像睡著了一般究履。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上脸狸,一...
    開封第一講書人閱讀 49,031評(píng)論 1 285
  • 那天最仑,我揣著相機(jī)與錄音,去河邊找鬼肥惭。 笑死盯仪,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蜜葱。 我是一名探鬼主播,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼耀石,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼牵囤!你這毒婦竟也來了爸黄?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤揭鳞,失蹤者是張志新(化名)和其女友劉穎炕贵,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體野崇,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡称开,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了乓梨。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鳖轰。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖扶镀,靈堂內(nèi)的尸體忽然破棺而出蕴侣,到底是詐尸還是另有隱情,我是刑警寧澤臭觉,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布昆雀,位于F島的核電站,受9級(jí)特大地震影響蝠筑,放射性物質(zhì)發(fā)生泄漏狞膘。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一什乙、第九天 我趴在偏房一處隱蔽的房頂上張望客冈。 院中可真熱鬧,春花似錦稳强、人聲如沸场仲。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽渠缕。三九已至,卻和暖如春褒繁,著一層夾襖步出監(jiān)牢的瞬間亦鳞,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工棒坏, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留燕差,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓坝冕,卻偏偏與公主長(zhǎng)得像徒探,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子喂窟,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容