用vue点击做一个下拉的动态效果
时间: 2023-07-20 13:14:19 浏览: 78
好的,下面是一个简单的示例代码:
```html
<template>
<div class="dropdown">
<button class="dropdown-btn" @click="toggleDropdown">{{ selectedOption }}</button>
<ul class="dropdown-menu" :class="{ open: isDropdownOpen }">
<li v-for="(option, index) in options" :key="index" @click="selectOption(index)">
{{ option }}
</li>
</ul>
</div>
</template>
<script>
export default {
data() {
return {
options: ['Option 1', 'Option 2', 'Option 3'],
selectedOption: 'Select an option',
isDropdownOpen: false
}
},
methods: {
toggleDropdown() {
this.isDropdownOpen = !this.isDropdownOpen
},
selectOption(index) {
this.selectedOption = this.options[index]
this.isDropdownOpen = false
}
}
}
</script>
<style>
.dropdown {
position: relative;
display: inline-block;
}
.dropdown-btn {
padding: 10px 20px;
background-color: #f3f3f3;
border: none;
cursor: pointer;
}
.dropdown-menu {
position: absolute;
top: 100%;
left: 0;
right: 0;
padding: 0;
margin: 0;
background-color: #fff;
border: 1px solid #ccc;
border-top: none;
list-style: none;
display: none;
z-index: 1;
}
.dropdown-menu.open {
display: block;
}
.dropdown-menu li {
padding: 10px 20px;
cursor: pointer;
}
.dropdown-menu li:hover {
background-color: #f3f3f3;
}
</style>
```
上述代码实现了一个简单的下拉菜单,点击按钮即可展开或收起下拉菜单。其中,`:class="{ open: isDropdownOpen }"` 用于动态绑定下拉菜单的显示/隐藏状态,`@click` 用于绑定点击事件,当用户点击下拉菜单中的选项时,会触发 `selectOption` 方法,将选中的选项赋值给 `selectedOption`。您可以根据实际需求进行修改和优化。
阅读全文