为什么写上这个 @selection-change,一点击就没有数据了
时间: 2024-04-20 15:23:40 浏览: 171
@selection-change 是一个 Vue.js 的事件监听器,用于监听选择框的选项变化事件。当你写上 @selection-change="handleselectionchange" 时,它会调用名为 handleselectionchange 的方法来处理选择框的选项变化。
关于点击后没有数据的问题,可能是因为在 handleselectionchange 方法中没有正确地更新数据或者获取数据的逻辑有问题。你可以检查一下 handleselectionchange 方法的实现,确保它正确地获取到了数据,并将数据更新到你期望的位置。
如果你能提供更多的代码或者具体的错误信息,我可以帮助你更精确地找到问题所在。
相关问题
<template> <el-row> <basic-container> <avue-crud :option="option" :table-loading="loading" :data="dataList" :options="tableOptions" :page="page" :search="query" :permission="permissionList" :before-open="beforeOpen" :sortKey="sortKey" :sortOrder="sortOrder" :default-sort = "{prop: 'statusTime', order: 'String'}" @sort-change="handleSortChange" v-model="form" ref="crud" @row-update="rowUpdate" @row-save="rowSave" @row-del="rowDel" @search-change="searchChange" @search-reset="searchReset" @selection-change="selectionChange" @current-change="currentChange" @size-change="sizeChange" @refresh-change="refreshChange" @on-load="onLoad"> <template slot="menuLeft" > <el-button type="primary" size="small" icon="el-icon-delete" plain ref="form" v-model="form" :option="option" @click="handleDelete">删 除 </el-button> </template> export default { data() { return { column: [ { label: "设备组", prop: "groupId", filters:true, search: "true", dicData:[], //清空 // clearable:false, type: 'tree', rules: [{ required: true, message: "请输入设备名", trigger: "blur" }] },] }}} 基于AVUE 框架 在自定义的删除按钮 绑定 设备组的搜索框 的输入值 输入搜索信息 点击删除按钮 获取到当前输入框的值
你可以使用AVUE框架来自定义删除按钮,并将设备组的搜索框的输入值与删除按钮绑定。下面是一个示例代码,展示了如何在点击删除按钮时获取当前搜索框的值:
```html
<template>
<el-row>
<basic-container>
<avue-crud
:option="option"
:table-loading="loading"
:data="dataList"
:options="tableOptions"
:page="page"
:search="query"
:permission="permissionList"
:before-open="beforeOpen"
:sortKey="sortKey"
:sortOrder="sortOrder"
:default-sort="{ prop: 'statusTime', order: 'String' }"
@sort-change="handleSortChange"
v-model="form"
ref="crud"
@row-update="rowUpdate"
@row-save="rowSave"
@row-del="rowDel"
@search-change="searchChange"
@search-reset="searchReset"
@selection-change="selectionChange"
@current-change="currentChange"
@size-change="sizeChange"
@refresh-change="refreshChange"
@on-load="onLoad"
>
<template slot="menuLeft">
<el-button
type="primary"
size="small"
icon="el-icon-delete"
plain
ref="form"
v-model="form"
:option="option"
@click="handleDelete"
>
删除
</el-button>
</template>
</avue-crud>
</basic-container>
</el-row>
</template>
<script>
export default {
data() {
return {
column: [
{
label: "设备组",
prop: "groupId",
filters: true,
search: true,
dicData: [],
//清空
// clearable:false,
type: 'tree',
rules: [
{
required: true,
message: "请输入设备名",
trigger: "blur"
}
]
}
],
form: {}, // 表单数据
query: {}, // 搜索数据
};
},
methods: {
handleDelete() {
// 获取当前搜索框的值
const groupId = this.query.groupId;
console.log(groupId);
// 在这里执行删除操作
},
},
};
</script>
```
在这个示例中,我们在AVue CRUD组件中添加了一个自定义的删除按钮,并将其绑定到`handleDelete`方法。在`handleDelete`方法中,我们可以通过`this.query.groupId`获取当前搜索框的值,并进行相应的操作。请根据实际情况修改代码,并执行适当的删除操作。
Table(ref="refundTable" stripe :columns="tableCourseColumns" :data="MainContractCourseList" @on-selection-change="updateTable")怎么直接置灰这一行
在Vue.js中,如果你想直接将`Table`组件中的一行设置为灰色(即禁用选中状态),你可以通过在`<tr>`元素上添加一个自定义的class或者样式属性。假设你想让数据中的某一项`MainContractCourseList[index].disabled = true`时,那行变为灰色,可以这样做:
```html
<tr v-for="(course, index) in MainContractCourseList" :key="index" :class="{ 'gray-row': course.disabled }">
<!-- ...表头列... -->
<td @click="updateTable(course)">...</td>
</tr>
<style scoped>
.gray-row {
background-color: #ccc; /* 设置灰色背景颜色,也可以用CSS class进行更精细的控制 */
cursor: not-allowed; /* 禁止点击 */
}
</style>
```
在这个例子中,当`course.disabled`为`true`时,`gray-row`这个类会被应用,使得对应行显示为灰色。同时,`cursor:not-allowed`阻止了点击事件。
阅读全文