原文链接

前言

又开始一个全新的项目,每天都要元气满满呀~在划分模块和创建单页面组件时,常常写到name。嵌套路由中,index.vue极为常见,那么在vue中,export default { name: 'xxx'} 中的name到底有啥作用呢?

开始

还是先回到官方的文档:https://cn.vuejs.org/v2/api/#name

官方描述

官方文档已经给我们描述了两种使用情况,可能在开发中,并不是常用,举例子说明一下。

实践

1.组件自身的递归调用,就是在当前组件中,调用组件自己
componentA.vue

 
  1. <template>

  2. <div class="component-a">

  3. <!-- 一个简单的树形组件 -->

  4. <tree :treeData="treeData"></tree>

  5. </div>

  6. </template>

  7. <script>

  8. export default {

  9. name: 'component-a',

  10. data() {

  11. return {

  12. treeData: [{

  13. title: '树形标题一',

  14. expand: true,

  15. children: [{

  16. title: '子标题1',

  17. expand: true

  18. },

  19. {

  20. title: '子标题2',

  21. expand: true,

  22. children: [{

  23. title: '子标题2.1',

  24. expand: true

  25. },

  26. {

  27. title: '子标题2.2',

  28. expand: true

  29. },

  30. {

  31. title: '子标题2.3',

  32. expand: true

  33. }]

  34. }]

  35. }

  36. },

  37. components: {

  38. // 自定义组件

  39. tree: {

  40. // 组件的名称

  41. name: 'tree',

  42. // 模板

  43. template: `

  44. <ul>

  45. <li v-for="item in treeData">

  46. <span>{{item.title}}</span>

  47. <!-- 在组件内部调用自己 -->

  48. <tree v-if="item.children" :treeData="item.children"></tree >

  49. </li>

  50. </ul>`,

  51. // 通过父组件传递的数据

  52. props: ['treeData']

  53. }

  54. },

  55. methods: {}

  56. }

  57. </script>

  58. <style lang="less" scoped></style>

看一下效果图:

 树形效果图

2.当我们使用vue.js官方提供的调试工具调试时,可以看到组件的名称,更好地定位

vue devtools

3.最后一种应该是使用比较多的情况,就是当我们使用 keep-alive时可以使用include和exclude指定需要缓存和不需要缓存的组件。指定的依据就是组件的name。

官方文档:https://cn.vuejs.org/v2/api/#keep-alive
keep-alive

总结

以上就是vue.js中组件export default 中name的三种作用。调试和keep-alive是我们开发中常用的功能,关于组件的递归调用,还是第一次实践,递归时,大家一定要注意递归的条件,否则会进入死循环。

另外呢,给大家找了几篇关于组件递归的文章,希望给大家更多的参考~

https://blog.csdn.net/weixin_40814356/article/details/80283882

https://blog.csdn.net/zhaoxiang66/article/details/80940762 

刚好我自己的项目引入了iView框架,并且使用了其中的Tree组件,我们顺便看看它的源码吧~

iView源码

好啦~万圣节前夕,今晚一定要出去嗨哦,嘻嘻....生活会有彩蛋哦

Logo

前往低代码交流专区

更多推荐