将这个通讯录可以用拼音排序,并附加搜索功能,并可以点击跳转到聊天页面
时间: 2024-04-16 22:26:32 浏览: 91
要实现通讯录的拼音排序、搜索功能和点击跳转到聊天页面的功能,你需要进行以下修改:
1. 在 `data()` 中新增一个属性 `sortedContacts`,用于存储按拼音排序后的联系人列表。
2. 在 `created()` 生命周期钩子函数中调用一个方法 `sortContacts()`,用于初始化并排序联系人列表。
3. 在 `methods` 中新增一个方法 `sortContacts()`,用于将联系人列表按拼音排序,并将排序后的结果保存到 `sortedContacts` 中。
4. 在模板中的联系人列表循环部分,将联系人信息改为从 `sortedContacts` 中取值。
5. 新增一个输入框和搜索按钮,用于搜索联系人。
6. 在 `methods` 中新增一个方法 `searchContact()`,用于根据输入的搜索关键词过滤联系人列表,并更新显示结果。
7. 在模板中的搜索按钮上绑定 `@click="searchContact"`。
8. 为每个联系人项添加点击事件,跳转到聊天页面。
下面是修改后的代码:
```vue
<template>
<view class="container">
<view class="title">通讯录</view>
<view class="search-container">
<input class="search-input" v-model="searchKeyword" placeholder="请输入搜索关键词" />
<button class="search-button" @click="searchContact">搜索</button>
</view>
<view class="contact-list">
<view class="contact-item" v-for="(contact, index) in sortedContacts" :key="index" @click="goToChatPage(contact)">
<view class="contact-info">
<view class="contact-name">{{ contact.name }}</view>
<view class="contact-phone">{{ contact.phone }}</view>
</view>
<button class="contact-delete" @click="deleteContact(index)">删除</button>
</view>
</view>
<button class="add-contact" @click="addContact">添加联系人</button>
</view>
</template>
<script>
export default {
data() {
return {
contacts: [
{ name: '张三', phone: '13888888888' },
{ name: '李四', phone: '13999999999' },
{ name: '王五', phone: '13666666666' },
],
sortedContacts: [],
searchKeyword: '',
};
},
created() {
this.sortContacts();
},
methods: {
sortContacts() {
this.sortedContacts = this.contacts.sort((a, b) => a.name.localeCompare(b.name, 'zh'));
},
addContact() {
uni.navigateTo({
url: '/pages/addContact/addContact',
});
},
deleteContact(index) {
this.contacts.splice(index, 1);
this.sortContacts();
},
searchContact() {
if (this.searchKeyword === '') {
this.sortContacts();
} else {
this.sortedContacts = this.contacts.filter((contact) =>
contact.name.includes(this.searchKeyword)
);
}
},
goToChatPage(contact) {
// 在这里实现跳转到聊天页面的逻辑,可以使用 uni.navigateTo 方法,传递参数给聊天页面
// 示例:uni.navigateTo({ url: '/pages/chatPage/chatPage?contact=' + JSON.stringify(contact) });
},
},
};
</script>
<style scoped>
.container {
padding: 20rpx;
}
.title {
font-size: 32rpx;
text-align: center;
}
.search-container {
display: flex;
align-items: center;
margin-bottom: 10rpx;
}
.search-input {
flex: 1;
height: 60rpx;
line-height: 60rpx;
padding: 0 20rpx;
font-size: 28rpx;
border-radius: 30rpx;
border: 1rpx solid #999999;
}
.search-button {
width: 160rpx;
height: 60rpx;
line-height: 60rpx;
margin-left: 10rpx;
font-size: 28rpx;
background-color: #007aff;
color: #ffffff;
}
.contact-list {
margin-top: 20rpx;
}
.contact-item {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 10rpx;
}
.contact-info {
flex: 1;
}
.contact-name {
font-size: 28rpx;
margin-bottom: 6rpx;
}
.contact-phone {
font-size: 24rpx;
color: #999999;
}
.contact-delete {
font-size: 24rpx;
color: #ff0000;
}
.add-contact {
margin-top: 20rpx;
width: 100%;
height: 60rpx;
line-height: 60rpx;
text-align: center;
font-size: 28rpx;
background-color: #007aff;
color: #ffffff;
}
</style>
```
请注意,上述代码中的 `goToChatPage()` 方法只是一个示例,你需要根据你的具体需求来实现跳转到聊天页面的逻辑。
希望这次的修改满足了你的需求。如果还有其他问题,请随时提问!
阅读全文