【前端笔记 】 Vue 报错: Do not use built-in or reserved HTML elements as component id: a

在这里插入图片描述
这是因为我在研究keep-alive缓存做demo的时候把组件的name命名为a了,a在html中是链接标签,vue组件的命名不要与原生的html标签相同,具体使用报错的例子为:

Vue.component("tab-home", {
  name: 'a',
  template: "<div>Home component<input type='text'/></div>"
});

特此记录一下,已提醒自己。

整体报错代码环境如下:

<!DOCTYPE html>
<html>
  <head>
    <title>Dynamic Components Example</title>
    <style>
      .tab-button {
        padding: 6px 10px;
        border-top-left-radius: 3px;
        border-top-right-radius: 3px;
        border: 1px solid #ccc;
        cursor: pointer;
        background: #f0f0f0;
        margin-bottom: -1px;
        margin-right: -1px;
      }
      .tab-button:hover {
        background: #e0e0e0;
      }
      .tab-button.active {
        background: #e0e0e0;
      }
      .tab {
        border: 1px solid #ccc;
        padding: 10px;
      }
    </style>
  </head>
  <body>
    <div id="dynamic-component-demo" class="demo">
      <button
        v-for="tab in tabs"
        v-bind:key="tab"
        v-bind:class="['tab-button', { active: currentTab === tab }]"
        v-on:click="currentTab = tab"
      >
        {{ tab }}
      </button>
      <keep-alive :include="['a','bn','cn']">
            <component v-bind:is="currentTabComponent" class="tab"></component>
      </keep-alve>
    </div>
    <script src="https://cn.vuejs.org/js/vue.js"></script>

    <script>
      Vue.component("tab-home", {
        name: 'a',
        template: "<div>Home component<input type='text'/></div>"
      });
      Vue.component("tab-posts", {
        name: 'bn',
        template: "<div>Posts component<input type='text'/></div>"
      });
      Vue.component("tab-archive", {
        name: 'cn',
        template: "<div>Archive component<input type='text'/></div>"
      });

      new Vue({
        el: "#dynamic-component-demo",
        data: {
          currentTab: "Home",
          tabs: ["Home", "Posts", "Archive"]
        },
        computed: {
          currentTabComponent: function() {
            return "tab-" + this.currentTab.toLowerCase();
          }
        }
      });
    </script>
  </body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值