Я хотел бы знать, что написано в названии. Я пытаюсь использовать разрешенный компонент v-alert и хочу добавить некоторые функции, когда пользователь нажимает кнопку закрытия. При чтении документов в слоте Закрыть есть функция переключать, которая «Переключает активное состояние предупреждения. Доступно в слоте закрытия и используется как действие щелчка в отклонить».
https://vuetifyjs.com/en/api/v-alert/#functions
https://vuetifyjs.com/en/api/v-alert/#slots-close
Ниже вы найдете то, что я безуспешно пробовал:
<template>
<div id = "app">
<v-app>
<v-alert dismissible v-model = "message">
{{ message }}
<template v-slot:close = "{ toggle }">
<v-btn color = "primary" dark @click = "myFunction"> Dismiss </v-btn>
</template>
</v-alert>
</v-app>
</div>
</template>
<script>
export default {
name: "App",
data: () => ({
message: "The message",
}),
methods: {
myFunction() {
console.info("do something before dismiss");
},
},
};
</script>



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Этот слот возвращает функцию, называемую переключением. Одно из возможных решений - передать эту функцию вашей пользовательской функции, делать там, где вы хотите, а затем вызвать функцию переключения.
https://codepen.io/vinisalves/pen/poRrjOY?editors=1010
<div id = "app">
<v-app>
<v-alert dismissible v-model = "myAlertModel">
{{ message }}
<template v-slot:close = "{ toggle }">
<v-btn color = "primary" dark @click = "myFunction(toggle)"> Dismiss </v-btn>
</template>
</v-alert>
</v-app>
</div>
new Vue({
el: '#app',
vuetify: new Vuetify(),
data: () => ({
message: "The message",
myAlertModel: true,
}),
methods: {
myFunction(dismissFn) {
console.info("do something before dismiss");
dismissFn();
},
},
})
Другая проблема заключается в том, что v-модель ожидает логическое значение, а не строку.