首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Vue.js中创建自定义组件

在Vue.js中创建自定义组件
EN

Stack Overflow用户
提问于 2020-05-09 02:46:53
回答 2查看 284关注 0票数 0

我目前正在学习JavaScript、HTML和Vue.Js,现在正在学习如何使用组件。我正在上一个使用机器人改正代码的在线课程。

任务是创建一个组件greet,该组件在使用<greet></greet>调用时生成<div>hello!</div>。要完成分配,我需要使用Vue.Componenttemplete-key。我需要在new Vue-caller中设置el-value,以便它与<div id="app"></div>匹配

到目前为止,这是在我的HTML代码中(包括脚本src ):

代码语言:javascript
复制
<body>
    <div id="app">
      <greet="greet"></greet>
    </div>
  </body>

到目前为止,这是我的Vue代码

代码语言:javascript
复制
new Vue({ el: '#app' })
Vue.component('greet', {
  data() {
    return {
      greet
    }
  },
  template: '<div>hello!</div>'
})

HTML页面上的输出是空白的,所以我不明白这里遗漏了什么。

机器人的输出是:

代码语言:javascript
复制
file.js
    ✓ exists
    ✓ is valid JavaScript
    1) renders the correct markup
EN

回答 2

Stack Overflow用户

发布于 2020-05-09 03:21:36

这里有几个错误。

首先,<greet="greet"></greet>不起作用。在vue中有一个名为props的东西(您将在以后学习它),将该行更改为<greet></greet>

这样你就不必使用data()来显示hello div了。从数据中删除greet

以上步骤可能会修复您的错误

票数 0
EN

Stack Overflow用户

发布于 2020-05-09 03:23:50

当您使用语法Vue.component()时,您是在全局注册一个组件,因此以后创建的任何新的Vue实例都可以使用它。所以:

代码语言:javascript
复制
new Vue({ el: '#app' }) // this Vue instance does not contain the greet component because it does not exists yet. 
Vue.component('greet', {
  data() {
    return {

    }
  },
  template: '<div>hello!</div>'
})

而是:

代码语言:javascript
复制
Vue.component('greet', {
  data() {
    return {

    }
  },
  template: '<div>hello!</div>'
})

new Vue({ el: '#app' }) // this Vue instance will contain the greet component because it was already created and registered.

此外,<greet="greet"></greet>不是有效的语法。应该是<greet></greet>

您应该从data()函数中删除greet。它没有任何意义和用途。

最终的代码应该如下所示:

代码语言:javascript
复制
<body>
    <div id="app">
      <greet></greet>
    </div>
</body>


Vue.component('greet', {
  template: '<div>hello!</div>'
})

new Vue({ el: '#app' })
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61685987

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档