搜索昵称显示问题
This commit is contained in:
parent
89cf6ec570
commit
b068d82b21
|
|
@ -5,29 +5,37 @@
|
|||
<custom-navbar ref="customNavbar" title="往生供奉" />
|
||||
<view class="container">
|
||||
<!-- 状态展示 -->
|
||||
<status-display v-if="loading" type="loading" loading-text="搜索中..." />
|
||||
<status-display v-if="loading" loading-text="搜索中..." type="loading" />
|
||||
|
||||
<!-- 搜索框 -->
|
||||
<search-box
|
||||
v-model="searchName"
|
||||
:width="'682rpx'"
|
||||
:search-icon="CommonEnum.SEARCH"
|
||||
placeholder="请输入姓名进行查找"
|
||||
:width="'682rpx'"
|
||||
btn-text="搜索"
|
||||
placeholder="请输入姓名进行查找"
|
||||
@search="handleSearch"
|
||||
/>
|
||||
<view class="body">
|
||||
<view class="center-files">
|
||||
<image :src="CommonEnum.CENTER_TILES" mode="aspectFit" class="files"></image>
|
||||
<image
|
||||
:src="CommonEnum.CENTER_TILES"
|
||||
class="files"
|
||||
mode="aspectFit"
|
||||
></image>
|
||||
</view>
|
||||
<!-- 搜索结果 -->
|
||||
<view class="search-results" v-if="searchResults.length > 0">
|
||||
<view class="result-card" v-for="(item, index) in searchResults" :key="index">
|
||||
<view v-if="searchResults.length > 0" class="search-results">
|
||||
<view
|
||||
v-for="(item, index) in searchResults"
|
||||
:key="index"
|
||||
class="result-card"
|
||||
>
|
||||
<!-- 卡片头部 -->
|
||||
<view class="card-header">
|
||||
<view class="header-info">
|
||||
<text class="label">牌位名称</text>
|
||||
<text class="label">编号(分区)</text>
|
||||
<!-- <text class="label">牌位名称</text>-->
|
||||
<text class="label">编号{{ item.code }}</text>
|
||||
</view>
|
||||
<view class="view-details" @click="viewDetails(item)">
|
||||
<text class="details-text">查看详情 ></text>
|
||||
|
|
@ -37,9 +45,9 @@
|
|||
<!-- 姓名标签区域 -->
|
||||
<view class="names-section">
|
||||
<view
|
||||
class="name-tag"
|
||||
v-for="(name, nameIndex) in item.names"
|
||||
:key="nameIndex"
|
||||
class="name-tag"
|
||||
@click="selectName(item, name)"
|
||||
>
|
||||
<text class="name-text">{{ name }}</text>
|
||||
|
|
@ -49,30 +57,37 @@
|
|||
</view>
|
||||
|
||||
<!-- 空状态 -->
|
||||
<view class="empty-state" v-if="hasSearched && searchResults.length === 0">
|
||||
<view
|
||||
v-if="hasSearched && searchResults.length === 0"
|
||||
class="empty-state"
|
||||
>
|
||||
<text class="empty-text">未找到相关往生者信息</text>
|
||||
</view>
|
||||
|
||||
<!-- 初始状态提示 -->
|
||||
<view class="initial-state" v-if="!hasSearched">
|
||||
<view v-if="!hasSearched" class="initial-state">
|
||||
<text class="initial-text">请输入姓名进行搜索</text>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
|
||||
<view class="bottom-files">
|
||||
<image :src="CommonEnum.BOTTOM_TILES_2" mode="aspectFit" class="files"></image>
|
||||
<image
|
||||
:src="CommonEnum.BOTTOM_TILES_2"
|
||||
class="files"
|
||||
mode="aspectFit"
|
||||
></image>
|
||||
</view>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import { CommonEnum } from '@/enum/common.js'
|
||||
import SearchBox from '../../components/search-box/search-box.vue'
|
||||
import StatusDisplay from '../../components/status-display/status-display.vue'
|
||||
import { searchDeceased } from '@/api/memorial/memorial.js'
|
||||
import { CommonEnum } from "@/enum/common.js";
|
||||
import SearchBox from "../../components/search-box/search-box.vue";
|
||||
import StatusDisplay from "../../components/status-display/status-display.vue";
|
||||
import { searchDeceased } from "@/api/memorial/memorial.js";
|
||||
|
||||
export default {
|
||||
export default {
|
||||
components: {
|
||||
SearchBox,
|
||||
StatusDisplay,
|
||||
|
|
@ -80,96 +95,96 @@
|
|||
data() {
|
||||
return {
|
||||
CommonEnum,
|
||||
searchName: '',
|
||||
searchName: "",
|
||||
loading: false,
|
||||
searchResults: [],
|
||||
hasSearched: false,
|
||||
}
|
||||
};
|
||||
},
|
||||
onLoad(options) {
|
||||
console.log('deceasedSearch页面接收到的参数:', options)
|
||||
console.log("deceasedSearch页面接收到的参数:", options);
|
||||
|
||||
// 从路由参数获取搜索关键词
|
||||
if (options.keyword) {
|
||||
this.searchName = decodeURIComponent(options.keyword)
|
||||
console.log('接收到搜索关键词:', this.searchName)
|
||||
this.searchName = decodeURIComponent(options.keyword);
|
||||
console.log("接收到搜索关键词:", this.searchName);
|
||||
|
||||
// 自动执行搜索
|
||||
this.$nextTick(() => {
|
||||
this.handleSearch(this.searchName)
|
||||
})
|
||||
this.handleSearch(this.searchName);
|
||||
});
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
// 处理搜索
|
||||
async handleSearch(value) {
|
||||
if (!value || value.trim() === '') {
|
||||
if (!value || value.trim() === "") {
|
||||
uni.showToast({
|
||||
title: '请输入搜索内容',
|
||||
icon: 'none',
|
||||
})
|
||||
return
|
||||
title: "请输入搜索内容",
|
||||
icon: "none",
|
||||
});
|
||||
return;
|
||||
}
|
||||
|
||||
this.loading = true
|
||||
this.hasSearched = true
|
||||
this.loading = true;
|
||||
this.hasSearched = true;
|
||||
|
||||
try {
|
||||
const res = await searchDeceased({
|
||||
fullName: value.trim(),
|
||||
})
|
||||
});
|
||||
|
||||
if (res.code === 200) {
|
||||
this.searchResults = res.data || []
|
||||
this.searchResults = res.data || [];
|
||||
if (this.searchResults.length === 0) {
|
||||
uni.showToast({
|
||||
title: '未找到相关结果',
|
||||
icon: 'none',
|
||||
})
|
||||
title: "未找到相关结果",
|
||||
icon: "none",
|
||||
});
|
||||
}
|
||||
} else {
|
||||
throw new Error(res.msg || '搜索失败')
|
||||
throw new Error(res.msg || "搜索失败");
|
||||
}
|
||||
} catch (error) {
|
||||
console.error('搜索失败:', error)
|
||||
this.searchResults = []
|
||||
console.error("搜索失败:", error);
|
||||
this.searchResults = [];
|
||||
uni.showToast({
|
||||
title: error.message || '搜索失败',
|
||||
icon: 'none',
|
||||
})
|
||||
title: error.message || "搜索失败",
|
||||
icon: "none",
|
||||
});
|
||||
} finally {
|
||||
this.loading = false
|
||||
this.loading = false;
|
||||
}
|
||||
},
|
||||
|
||||
// 查看详情
|
||||
viewDetails(item) {
|
||||
console.log('查看详情:', item)
|
||||
console.log("查看详情:", item);
|
||||
// 跳转到往生大殿页面
|
||||
uni.navigateTo({
|
||||
url: `/pages/memorial/memorialHall?id=${item.id}`,
|
||||
})
|
||||
});
|
||||
},
|
||||
|
||||
// 选择姓名
|
||||
selectName(item, name) {
|
||||
console.log('选择姓名:', name, '来自牌位:', item)
|
||||
console.log("选择姓名:", name, "来自牌位:", item);
|
||||
// 可以跳转到该姓名的详情页面或执行其他操作
|
||||
uni.navigateTo({
|
||||
url: `/pages/memorial/enshrinedList?id=${item.id}&name=${encodeURIComponent(name)}`,
|
||||
})
|
||||
});
|
||||
},
|
||||
},
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
.page {
|
||||
.page {
|
||||
width: 100%;
|
||||
min-height: 100vh;
|
||||
}
|
||||
}
|
||||
|
||||
.container {
|
||||
.container {
|
||||
width: 100%;
|
||||
//min-height: 100vh;
|
||||
display: flex;
|
||||
|
|
@ -196,30 +211,30 @@
|
|||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 搜索结果区域
|
||||
.search-results {
|
||||
// 搜索结果区域
|
||||
.search-results {
|
||||
display: flex;
|
||||
width: 100%;
|
||||
margin-top: 20rpx;
|
||||
align-items: center;
|
||||
flex-direction: column;
|
||||
gap: 22rpx;
|
||||
}
|
||||
}
|
||||
|
||||
// 结果卡片
|
||||
.result-card {
|
||||
// 结果卡片
|
||||
.result-card {
|
||||
padding: 40rpx;
|
||||
width: 676rpx;
|
||||
height: 248rpx;
|
||||
background: #fffbf5;
|
||||
border-radius: 12rpx 12rpx 12rpx 12rpx;
|
||||
border: 1rpx solid #c7a26d;
|
||||
}
|
||||
}
|
||||
|
||||
// 卡片头部
|
||||
.card-header {
|
||||
// 卡片头部
|
||||
.card-header {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
|
|
@ -255,17 +270,17 @@
|
|||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 姓名标签区域
|
||||
.names-section {
|
||||
// 姓名标签区域
|
||||
.names-section {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
gap: 20rpx 22rpx;
|
||||
}
|
||||
}
|
||||
|
||||
// 姓名标签
|
||||
.name-tag {
|
||||
// 姓名标签
|
||||
.name-tag {
|
||||
cursor: pointer;
|
||||
transition: all 0.3s ease;
|
||||
background: #fff1dd;
|
||||
|
|
@ -284,10 +299,10 @@
|
|||
line-height: 32rpx;
|
||||
text-align: center;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 空状态
|
||||
.empty-state {
|
||||
// 空状态
|
||||
.empty-state {
|
||||
margin-top: 100rpx;
|
||||
text-align: center;
|
||||
|
||||
|
|
@ -295,10 +310,10 @@
|
|||
font-size: 28rpx;
|
||||
color: #999;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 初始状态
|
||||
.initial-state {
|
||||
// 初始状态
|
||||
.initial-state {
|
||||
margin-top: 100rpx;
|
||||
text-align: center;
|
||||
|
||||
|
|
@ -306,9 +321,9 @@
|
|||
font-size: 28rpx;
|
||||
color: #666;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
.bottom-files {
|
||||
.bottom-files {
|
||||
position: fixed;
|
||||
left: 0;
|
||||
bottom: 0;
|
||||
|
|
@ -320,5 +335,5 @@
|
|||
width: 750rpx;
|
||||
height: 90rpx;
|
||||
}
|
||||
}
|
||||
}
|
||||
</style>
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user