У меня есть список элементов, и я хочу, чтобы накормить свои данные из массива JavaScript:Как передать функцию с аргументами через массив объектов JavaScript?
// HTML
<ul
<li v-for="menuItem in menuItems">
<a @click="menuItem.action">{{ menuItem.name }}</a>
</li>
</ul>
// DATA
data() {
return {
menuItems: [
{ name: 'Split up', action: this.split('up') },
{ name: 'Split down', action: this.split('down') },
{ name: 'Split left', action: this.split('left') },
{ name: 'Split right', action: this.split('right') }
]
}
// METHODS
methods: {
split (direction) {
store.actions.openWindow(direction)
store.actions.closeMenu()
}
}
Но сейчас я получаю эту ошибку:
[Vue warn]: v-on:click="menuItem.action" expects a function value, got undefined
Это означает, что я ошибочно передавая значение action
.
Каков правильный способ?
Спасибо. Второй пример работает только так: 'action:() => {return this.split ('left')}'. – alexchenco