Vue简单组件封装之按钮组件

Vue简单组件封装之按钮组件

实现效果:传递不同的属性值,按钮名称和按钮颜色不一样

封装组件代码:
<template>
<input type="button" :class='type' :value='name' @click="defaultClick"/>
</template>

<script>
export default {
  name: "CoolButton",
  methods: {
    defaultClick () {
      console.log("按钮组件被点击了")
      this.$emit('btn-click')
    }
  },
  computed: {},
  props: {//调用该组件时需要传递过来的属性
    name:{
      type:String
    },
    type:{
      type:String
    }
  }
}
</script>

<style scoped>
/*按钮样式*/
input{
  border: none;
  padding: 2px 10px;
  border-radius: 6px;
  margin: 2px 6px;
  color:#fff
}
/*不同属性按钮颜色不同*/
.primary{background-color: #409eff}
.danger{background-color: #f56c6c}
.success{background-color: #67c23a}
.warning{background-color: #e6a23c}
</style>

调用组件代码:
/*在html里使用组件*/
//<cool-button type="primary" name="名字" @btn-click="a"></cool-button>
//<cool-button :type="typeParent" :name="nameParent" @btn-click="a"></cool-button>
<cool-button :type="'primary'" :name="'名字'" @btn-click="a"></cool-button>

//引入组件
import CoolButton from '@/views/Conformance/components/coolButton/cool-button.vue'
export default {
  name: "otherList",
  data() {
    return {
    typeParent:'primary',
    nameParent:'名字'
    },
  },
  components: {
   'cool-button':CoolButton,
  },
  computed: {},
  methods: {
   a(){
      console.log('调用按钮组件')
    }
};
</script>

效果及输出:

在这里插入图片描述

控制台输出:

按钮组件被点击了
调用按钮组件
Vue3组件封装非常简单,下面是一个搜索组件封装示例: 首先,创建一个 Search.vue组件,它的模板如下: ```html <template> <div class="search"> <input type="text" v-model="searchInput" @input="handleInput" /> <button @click="handleSearch">搜索</button> </div> </template> ``` 在组件中,我们需要引入 `reactive`,这是 Vue3 中新加入的函数,用于将数据转换为响应式的数据。我们还需要定义 `props`,用于接收父组件传递的参数,以及定义 `emit`,用于向父组件发送事件。 ```javascript import { defineComponent, reactive, emit } from &#39;vue&#39;; export default defineComponent({ name: &#39;Search&#39;, props: { placeholder: { type: String, default: &#39;请输入关键词&#39;, }, }, setup(props, { emit }) { const searchInput = reactive({ value: &#39;&#39;, }); const handleInput = (event) => { searchInput.value = event.target.value; }; const handleSearch = () => { emit(&#39;search&#39;, searchInput.value); }; return { searchInput, handleInput, handleSearch, }; }, }); ``` 在 `setup` 函数中,我们使用 `reactive` 将 `searchInput` 对象转换为响应式数据。当用户输入关键词时,`handleInput` 函数被调用,将输入的值赋值给 `searchInput.value`。当用户点击搜索按钮时,`handleSearch` 函数被调用,向父组件发送 `search` 事件,并将输入框的值作为参数传递给父组件。 最后,在父组件中使用该组件: ```html <template> <div> <Search placeholder="请输入关键词" @search="handleSearch" /> <ul> <li v-for="item in searchResult" :key="item.id">{{ item.name }}</li> </ul> </div> </template> <script> import Search from &#39;./Search.vue&#39;; export default { components: { Search, }, data() { return { searchResult: [], }; }, methods: { handleSearch(keywords) { // 这里实现搜索逻辑,将搜索结果赋值给 searchResult this.searchResult = [ { id: 1, name: &#39;搜索结果1&#39; }, { id: 2, name: &#39;搜索结果2&#39; }, { id: 3, name: &#39;搜索结果3&#39; }, ]; }, }, }; </script> ``` 在父组件中,我们通过 `@search` 监听子组件的 `search` 事件,并在 `handleSearch` 方法中实现搜索逻辑。将搜索结果赋值给 `searchResult`,然后通过 `v-for` 渲染出结果列表。 这就是 Vue3 中搜索组件封装方法,简单易用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值