第一步:$ npm install -g vue-cli
第二部:$ vue init webpack my-projectName
下面內容轉載自:https://www.cnblogs.com/chengjunL/p/6282125.html
在vue1.0版本的超鏈接標簽還是原來的a
標簽,鏈接地址由v-link
屬性控制
而vue2.0版本里超鏈接標簽由a
標簽被替換成了router-link
標簽,但最終在頁面還是會被渲染成a標簽的
至於為什么要把a換成router-link原因還是有的,比如我們之前一直慣用的nav導航里面結構是(ul>li>a),touter-link可以渲染為任何元素,這里可以直接渲染成li標簽,同樣能實現跳轉效果,節省了a標簽的使用,還有一個原因可能是因為a標簽正常是鏈接的跳轉的作用,點擊a時可能會重載頁面,使用router-link,此標簽會被vue所監聽,跳轉鏈接時就不會刷新頁面了。當然這個人理解,不對之處有望指正。
"router-link"屬性
1.":to" 屬 性
相當於a標簽中的"herf"屬性,后面跟跳轉鏈接所用
<router-link :to="/home">Home</router-link> <!-- 渲染結果 --> <a href="/home">Home</a>
2."replace" 屬 性
replace在routre-link標簽中添加后,頁面切換時不會留下歷史記錄
<router-link :to="/home" replace></router-link>
3."tag" 屬 性
具有tag屬性的router-link會被渲染成相應的標簽
<router-link :to="/home" tag="li">Home</router-link> <!-- 渲染結果 --> <li>Home</li>
此時頁面的li同樣會起到a鏈接跳轉的結果,vue會自動為其綁定點擊事件,並跳轉頁面
例子見下圖:
<router-link tag="li" to="/about0">
About0
</router-link>
4."active-class" 屬 性
這個屬性是設置激活鏈接時class屬性,也就是當前頁面所有與當前地址所匹配的的鏈接都會被添加class屬性
<router-link :to="/home" active-class="u-link--Active">Home</router-link>
active-class
屬性的默認值是router-link-active
,所以如果沒有設置,就會被渲染為這個class
可以在router.js里面設置
const router = new VueRouter({ mode: 'hash', linkActiveClass: 'u-link--Active', // 這是鏈接激活時的class })
也可以在樣式文件中寫:
.router-link-active{
background-color:red;
}
截圖例子是為了講解清楚:
5."exact" 屬 性
開啟router-link
的嚴格模式
<router-link :to="/" exact>home</router-link>
上面這個標簽如果不加exact
屬性,則會在vue2.leenty.com/article
頁面下也會被匹配到,
這卻不是我們的本意,在加了這個屬性后就會正確的匹配到vue2.leenty.com
下