我需要获取我单击的元素,该元素显示在列表中。并通过 index.html 上的邮件列表标签在我的 vue 实例上的方法上打印此元素
所以我有 Vue 组件,它迭代 json 对象并且只从它的每个元素中打印两个属性:
Vue.component('mail-list', {
props: ['inboxmail'],
methods: {
selectmail: function(){
this.$emit('selectmail', this.mail);
}
},
template:
`
<div>
<ul>
<li v-for="i in inboxmail" @click="selectedmail">
{{i.from}}:{{i.subject}}
</li>
</ul>
</div>
`
});
运行后,我的 index.html 上显示了两个元素,它们是:
test1@test.com:嗨
test2@test.com:你好吗?
我想单击这两个元素之一并获取我单击的那个。然后通过 index.html 中的邮件列表标签将其发送到名为 setSelectedMail 的 vue 方法
索引.html:
<div id="app">
<mail-list v-bind:inboxmail="inbox" @selectmail="setSelectedMail($event)"></mail-list>
</div>
最后,这是我要从中获取所选邮件的 vue 实例:
let options = {
el: "#app",
data: {
inbox: '',
selectedMail:{}
},
methods: {
setSelectedMail: function(mail){
this.selectedMail = mail;
}
} //end methods
}
//ViewModel (vm)
let vm = new Vue(options);
我究竟做错了什么?