在vue中通过鼠标引入控制一张表格 当鼠标悬浮在表格中的其中一行数据时 在下面打印在页面表格中的信息 包括编号姓名 性别年龄
时间: 2024-09-13 11:07:12 浏览: 46
在 Vue 中,你可以利用 `v-on` 指令结合事件监听 (`@mouseover`) 来实现这个功能。首先,你需要在 HTML 上设置一个表格元素,并给每一行添加一个唯一的标识(如 `row-id`),然后在模板中绑定 `mouseover` 事件。
```html
<table id="myTable">
<tr v-for="(item, index) in items" :key="index">
<td>{{ item编号 }}</td>
<td>{{ item姓名 }}</td>
<td>{{ item性别 }}</td>
<td>{{ item年龄 }}</td>
<td @mouseover="showInfo(index)">Hover</td> <!-- 添加 mouseover 事件 -->
</tr>
</table>
<!-- 元素用于显示行信息 -->
<div v-if="hoveredRow" class="info">
{{ hoveredData 编号 }} - {{ hoveredData 姓名 }}, {{ hoveredData 性别 }} ({{ hoveredData 年龄 }})
</div>
```
接下来,在你的 Vue 实例中定义 `items` 数据数组以及 `hoveredRow` 和 `hoveredData` 变量来跟踪当前悬停的行:
```javascript
export default {
data() {
return {
items: [
// 表格数据...
],
hoveredRow: null,
hoveredData: {},
};
},
methods: {
showInfo(rowIndex) {
this.hoveredRow = rowIndex;
this.hoveredData = this.items[rowIndex]; // 获取对应行的数据
},
},
};
```
当鼠标悬浮在某一行时,`showInfo` 方法会被触发,更新 `hoveredRow` 和 `hoveredData` 的值,然后在 `.info` 类的元素中动态地显示数据。记得在 CSS 中定义 `.info` 样式以便于呈现。
阅读全文