<template> <view class="c-card"> <view class="search"> <u-search placeholder="请输入客户名称" v-model="state.name" :showAction="false" :bgColor="'#fff'" :borderColor="'rgba(0, 0, 0, 0.1)'" :placeholderColor="'#C1C1C1'" @search="handleSearch()" ></u-search> <view class="btn" @click="add"> 新增 </view> </view> <view class="box"> <view v-for="(item, index) in pageList.list" :key="index"> <view> <view>{{ item.name }}</view> <view>联系人:{{ item.contacts }}</view> <view>卡号:{{ item.cardCode }}</view> </view> <view class="op-box"> <view class="btn" @click="edit(item)"> 编辑 </view> <view class="btn" @click="deleteCustomer(item)"> 删除 </view> </view> </view> </view> </view> </template> <script setup lang="ts"> import { CustomerApi } from "@/services"; const keyword = ref(""); const state = reactive<any>({ name: "", }); const pageList: PageResult<Customer> = reactive({ total: 0, list: [], pageNum: 1, pageSize: 10, }); const add = () => { uni.navigateTo({ url: "/pagesApp/components/addCustomer", // 要跳转到的页面路径 }); }; const edit = (item: any) => { uni.navigateTo({ url: "/pagesApp/components/addCustomer?title=编辑客户&item=" + JSON.stringify(item), // 要跳转到的页面路径 }); }; const deleteCustomer = (item: any) => { CustomerApi.updateCustomUser({ isDeleted: true, id: item.id }).then((res) => { if (res.code === 200) { getCustomUserPage(); } }); }; const handleSearch = () => { getCustomUserPage(); }; const getCustomUserPage = () => { let params: any = { pageSize: 10, pageNum: 1, name: state.name, }; if (state.supplierTypeId > -1) { params.supplierTypeId = state.supplierTypeId; } CustomerApi.getCustomUserPage(params).then((res) => { if (res.code === 200) { if (res.code === 200) { (pageList as any).list = (res.data as any).list; } } }); }; onMounted(() => { getCustomUserPage(); }); </script> <style lang="scss" scoped> .c-card { margin: 30rpx 25rpx; .search { display: flex; align-items: center; justify-content: space-between; .btn { background: #00dcee; border-radius: 24rpx; border: 1px solid #00dcee; font-weight: 500; font-size: 26rpx; color: #ffffff; margin-left: 50rpx; padding: 6rpx 30rpx; } } .box { background: #ffffff; box-shadow: 0rpx 0rpx 10rpx 0rpx rgba(5, 68, 37, 0.12); border-radius: 13rpx; padding: 10rpx 20rpx; font-weight: 400; font-size: 26rpx; color: #000000; line-height: 41rpx; margin-top: 30rpx; > view { display: flex; align-items: center; justify-content: space-between; padding: 20rpx 0rpx; .op-box { display: flex; .btn + .btn { margin-left: 20rpx; } .btn { background: #ff9d55; border-radius: 24rpx; font-weight: 500; font-size: 26rpx; color: #ffffff; padding: 6rpx 30rpx; } } } > view + view { border-top: 1px solid rgba(233, 233, 233, 0.76); } } } </style>