使用prop属性,(借助v-bind绑定)
<template> <div> <header-btn @handleSave="handleSave" @handleSubmit="handleSubmit" :headerBtns="headerBtns"/> </div> </template> <script> import HeaderBtn from "../../components/headerBtn.vue"; export default { components: { HeaderBtn, }, data() { return { headerBtns: [ {type: ‘primary‘, icon: ‘save‘, name: ‘保存‘, handleClick: ‘handleSave‘}, {type: ‘primary‘, icon: ‘check-submit‘, name: ‘提交‘, handleClick: ‘handleSubmit‘}, ], } }, methods: { handleSave() { console.log("handleSave"); }, handleSubmit() { console.log("handleSubmit"); } }, } </script>
<template> <div> <button v-for="(item,index) in headerBtns" :key="index" @click="$emit(item.handleClick)"> {{ item.name}} </button> </div> </template> <script> export default { name: "headerBtn", props: { headerBtns: { //父组件没有传参时,使用这个 type: Array, default() { return [ {type: ‘primary‘, icon: ‘goBack‘, name: ‘返回‘, handleClick: ‘handleBack‘}, {type: ‘primary‘, icon: ‘save‘, name: ‘保存‘, handleClick: ‘handleSave‘}, {type: ‘primary‘, icon: ‘check-submit‘, name: ‘提交‘, handleClick: ‘handleSubmit‘}, ] } } } } </script> <style scoped> </style>
这样就能封装一个button按钮,并带有点击事件
vue-cli 中使用父子之间传值_父组件传值子组件_封装button按钮
原文:https://www.cnblogs.com/dafei4/p/13196644.html