router-link标签
在vue1.0版本中的仍然用a标签来实现链接跳转功能,但链接地址与html中不同,它是采用v-link属性来控制。但是在2.0版本中a标签就被替换成了rount-link属性,但是最终在页面上显示还是会被渲染成a标签。接下来将要详细的介绍该属性中的各个值的用法
router-link属性值详解
(1)":to" 属性值
这个属性值就相当于a标签中的"herf"属性,后面的内容为跳转链接的内容
<router-link :to="http://www.gxlcms.com/">PHP中文网</router-link>
相当于
<a href="http://www.gxlcms.com/">PHP中文网</a>
(2)"replace" 属性值
replace属性值在routre-link标签中添加的主要目的在于页面切换时不会留下历史记录
<router-link :to="http://www.gxlcms.com/" replace></router-link>
(3)"tag" 属性值
具有tag属性的router-link都会被渲染成相应的标签
<router-link :to="/http://www.gxlcms.com/" tag="li">PHP中文网</router-link>
相当于
<li>PHP中文网</li>
此时的页面中的li同样会起到a标签的作用,因为vue会自动为其绑定点击事件,并跳转页面
(4)"active-class"属性值
这个属性是用于设置激活链接时class属性,也就是当前页面及所有与当前页面地址所匹配的的链接都会被添加class属性
<router-link :to="http://www.gxlcms.com/" active-class="u-link--Active">PHP中文网</router-link>
active-class属性的默认值是router-link-active,所以如果没有设置,就会被渲染为这个class
(5)“append”属性值
设置 append 属性后,则在当前 (相对) 路径前添加基路径。例如,我们从 /a 导航到一个相对路径 b,如果没有配置 append,则路径为 /b,如果配了,则为 /a/b
<router-link :to="{ path: 'relative/path'}" append></router-link>
使用router-link代替a标签的好处
router-link属性在页面中可以渲染为任何元素,比如上述代码中渲染成li标签依然实现了跳转效果。另外当我们点击a标签时可能会重载页面,但是使用router-link后此标签会被vue所监听,跳转链接时就不会刷新页面了