s-table中实现分页+单选

HTML

<!-- 筛选 -->
<a-form ref="searchFormRefOwner" name="advanced_search" :model="searchFormStateOwner" class="ant-advanced-search-form">
    <a-row :gutter="24">
        <a-col :span="14" style="margin-left: 30px">
            <a-form-item label="用户名称" name="account">
                <a-input v-model:value="searchFormStateOwner.account" placeholder="请输入用户名" />
            </a-form-item>
        </a-col>
        <a-col :span="8" style="margin-left: 30px">
            <a-button type="primary" @click="tableOwner.refresh(true)">查询</a-button>
            <a-button style="margin: 0 20px" @click="resetOwner">重置</a-button>
        </a-col>
    </a-row>
</a-form>

<!-- 表格 -->
<s-table
    ref="tableOwner"
    :columns="columns"
    :data="loadOwner"
    bordered
    :row-key="(record) => record.id"
    :row-selection="optionsOwner.rowSelection"
></s-table>

JS

<script setup name="xxx">

const tableOwner = ref()
let searchFormStateOwner = reactive({})
const searchFormRefOwner = ref()
const selectedRowKeys = ref([])

// 表格选择框配置
const optionsOwner = {
    // 如果没有指定为单选,那么当前选择几条记录,selectedRowKey就是几个key(id),selectedRows是几条完整数据
    rowSelection: {
        // 单选
        type: 'radio',
        // 切换复选框操作
        // selectedRowKe是当前所选记录的key,即id,(因为 :row-key="(record) => record.id")
        // selectedRows是指当前所选记录的完整数据
        onChange: (selectedRowKey, selectedRows) => {
            selectedRowKeys.value = selectedRowKey
        }
    }
}

const columns = [
    {
        title: 用户名称,
        dataIndex: 'account',
    },
    {
        title: 昵称,
        dataIndex: 'nickname'
    },
    {
        title: 用户ID,
        dataIndex: 'id',
    },
]

// 数据parameter中传有current、size进行分页
const loadOwner = (parameter) => {
  searchFormStateOwner.type = "COPYRIGHT"
  searchFormStateOwner.current = parameter.current
  searchFormStateOwner.size = parameter.size
  return xxApi.page(searchFormStateOwner).then(data => {
      return data
  })
}

// 重置
const resetOwner = () => {
  searchFormRefOwner.value.resetFields()
  tableOwner.value.refresh(true)
}
</script>

如下图:

结果输出(选择两次):

  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值