Communication between components, error "ReferenceError: tip is not defined"
<body>
<p id="app">
<button v-on:click="tip = !tip">Toggle</button>
<my-tip></my-tip>
</p>
</body>
<script type="text/javascript" src="../script/vue.js"></script>
<script type="text/javascript">
var tipTemplate = {
template: '<transition name="fade">\
<p v-if="tip" class="vertical-horizontal-center">\
<img src="../image/no-log.png">\
<h2>暂无记录</h2>\
<p class="aui-btn aui-btn-info">重新加载</p>\
</p>\
</transition>'
}
new Vue({
el: "#app",
data: {
tip: false,
},
components: {
'my-tip': tipTemplate,
props: ['tip'],
},
created: function() {}
})
</script>
It is recommended to read the document again and see the scope of the component
props: ['tip'] should be written in var tipTemplate={} instead of new Vue({}). The scope of the component is wrong
There is a problem with the answer above. Components need dynamic attribute binding:
The whole is as follows:
Add a v-if="tip" to the child component