VueJS道具在组件中未定义

Dor*_*ore 10 javascript django vue-component vuejs2

我正在尝试将VueJS与我的Django应用程序的前端集成.我在javascript文件中有以下Vue代码:

window.onload = function() {
    Vue.component('discuss-post', {
        props: ['post'],
        template:  `<div class="card">
                        <div class="grid-x margin-x">
                            <div class="cell small-4">
                                <img class="avatar-img" :src="post.by.profile.img_url">
                                <p style="font-family: Abel;font-size: 24px">{{ post.by }}</p>
                            </<div>
                        </div>
                        <div class="grid-x margin-x">
                            <div class="cell small-4">
                                <p style="font-family: Abel;font-size: 18px">{{ post.content }}</p>
                            </div>
                        </div>
                    </div>`
    })
    var postDiv = new Vue({
        el: "#post-div"
    })
}
Run Code Online (Sandbox Code Playgroud)

以及HTML文件中的以下代码:

            <div class="card-section">
                {% for feed in feeds %}
                {% for post in feed %}
                <div id="post-div">
                    <discuss-post post="{{ post }}"></discuss-post>
                </div>
                {% endfor %}
                {% endfor %}
            </div>
Run Code Online (Sandbox Code Playgroud)

但是,当我加载页面时,我在控制台中收到这些错误:

在此输入图像描述

我的代码中可能会引发这些错误?

Leo*_*Leo 5

信息不够清晰吗?什么是</<div>你的代码?

另一方面,v-bind如果要传递对象,请使用.{{ }}用于文本插值.


Nav*_*uja 5

编译模板错误删除/修复此标记:</<div>.此外,您必须将道具传递给子组件,如下所示:

<discuss-post :post="post"></discuss-post>

对于配置文件值错误,您必须检查数据中的JSON结构.

请参阅以下示例:

Vue.component('discuss-post', {
  props: ['post'],
  template: `<div class="card">
                     <div class="grid-x margin-x">
                       <div class="cell small-4">
                         <img class="avatar-img" :src="post.by.profile.img_url" />
                         <p style="font-family: Abel;font-size: 24px">{{ post.by }}</p>
                       <div>
                     </div>
               <div class="grid-x margin-x">
                 <div class="cell small-4">
                   <p style="font-family: Abel;font-size: 18px">{{ post.content }}</p>
                 </div>
               </div>
          </div>`
})
var postDiv = new Vue({
  el: "#post-div",
  data: function() {
    return {
      post: {
        content: "Post Content",
        by: {
          profile: {
            img_url: "http://www.gstatic.com/webp/gallery/1.jpg"
          }
        }
      }
    }
  }
})
Run Code Online (Sandbox Code Playgroud)
<script src="https://vuejs.org/js/vue.min.js"></script>
<div class="card-section">
  <div id="post-div">
    <discuss-post :post="post"></discuss-post>
  </div>
</div>
Run Code Online (Sandbox Code Playgroud)