16 搜索列表功能(组件复用思想,多种导航条跳转)
一 编辑三处跳转事件
1 pages/index/index.vue(原生导航栏)
//监听原生标题栏按钮点击事件,参数为Object
onNavigationBarSearchInputClicked(){
uni.navigateTo({
url:\'../search/search?type?post\',
})
},
2 pages/news/news.vue (在标签上自定跳转事件)
...
<!-- 搜索框 -->
<view class="p-2" @click="openSearch">
<view class="rounded w-100 flex align-center justify-center py-2" style="background-color: #F1F1F1;">
<text class="iconfont icon-sousuo"></text>
搜索话题
</view>
</view>
...
openSearch(){
uni.navigateTo({
url:\'../search/search?type=topic\'
})
},
3 pages/user-list/user-list.vue(原生导航栏)
// 监听点击输入框事件
onNavigationBarSearchInputClicked() {
uni.navigateTo({
url: \'../search/search?type=user\',
});
},
二 pages/search/search.vue(搜索占位符)
具体实现了:
1 不同页面搜索功能都跳转到了搜索组件
2 同一个搜索组件,根据type进行逻辑控制,渲染搜索占位+搜索内容
精华片段:
// 修改搜索占位
// #ifdef APP-PLUS
let currentWebview = this.$mp.page.$getAppWebview();
let tn = currentWebview.getStyle().titleNView;
tn.searchInput.placeholder = \'搜索\'+pageTitle;
currentWebview.setStyle({
titleNView: tn
})
// #endif
上代码:
<template>
<view>
<template v-if="searchList.length === 0">
<!-- 搜索历史 -->
<view class="py-2 font-md px-2">搜索历史</view>
<view class="flex flex-wrap">
<view class="border rounded font mx-2 my-1 px-2"
v-for="(item,index) in list" :key="index"
hover-class="bg-light"
@click="clickSearchHistory(item)">{{item}}</view>
</view>
</template>
<template v-else>
<!-- 数据列表 -->
<block v-for="(item,index) in searchList" :key="index">
<template v-if="type ===\'post\'">
<!-- 帖子 -->
<common-list :item="item" :index="index"></common-list>
</template>
<template v-else-if="type === \'topic\'">
<!-- 话题 -->
<topic-list :item="item" :index="index"></topic-list>
</template>
<template v-else>
<!-- 用户 -->
<user-list :item="item" :index="index"></user-list>
</template>
</block>
</template>
</view>
</template>
<script>
// 测试数据
const demo1 = [{
username:"昵称",
userpic:"/static/default.jpg",
newstime:"2019-10-20 下午04:30",
isFollow:false,
title:"我是标题",
titlepic:"/static/demo/datapic/11.jpg",
support:{
type:"support", // 顶
support_count:1,
unsupport_count:2
},
comment_count:2,
share_num:2
},
{
username:"昵称",
userpic:"/static/default.jpg",
newstime:"2019-10-20 下午04:30",
isFollow:false,
title:"我是标题",
titlepic:"",
support:{
type:"unsupport", // 踩
support_count:1,
unsupport_count:2
},
comment_count:2,
share_num:2
},
{
username:"昵称",
userpic:"/static/default.jpg",
newstime:"2019-10-20 下午04:30",
isFollow:false,
title:"我是标题",
titlepic:"",
support:{
type:"", // 未操作
support_count:1,
unsupport_count:2
},
comment_count:2,
share_num:2
}];
const demo2 = [{
cover:"/static/demo/topicpic/1.jpeg",
title:"话题名称",
desc:"话题描述",
today_count:0,
news_count:10
},{
cover:"/static/demo/topicpic/1.jpeg",
title:"话题名称",
desc:"话题描述",
today_count:0,
news_count:10
},{
cover:"/static/demo/topicpic/1.jpeg",
title:"话题名称",
desc:"话题描述",
today_count:0,
news_count:10
},{
cover:"/static/demo/topicpic/1.jpeg",
title:"话题名称",
desc:"话题描述",
today_count:0,
news_count:10
},{
cover:"/static/demo/topicpic/1.jpeg",
title:"话题名称",
desc:"话题描述",
today_count:0,
news_count:10
},{
cover:"/static/demo/topicpic/1.jpeg",
title:"话题名称",
desc:"话题描述",
today_count:0,
news_count:10
},{
cover:"/static/demo/topicpic/1.jpeg",
title:"话题名称",
desc:"话题描述",
today_count:0,
news_count:10
},{
cover:"/static/demo/topicpic/1.jpeg",
title:"话题名称",
desc:"话题描述",
today_count:0,
news_count:10
},{
cover:"/static/demo/topicpic/1.jpeg",
title:"话题名称",
desc:"话题描述",
today_count:0,
news_count:10
},{
cover:"/static/demo/topicpic/1.jpeg",
title:"话题名称",
desc:"话题描述",
today_count:0,
news_count:10
}];
const demo3 = [{
avatar:"/static/default.jpg",
username:"昵称",
sex:1, // 0未知,1女性,2男性
age:24,
isFollow:true
},{
avatar:"/static/default.jpg",
username:"昵称",
sex:2, // 0未知,1女性,2男性
age:24,
isFollow:false
}];
import commonList from \'@/components/common/common-list.vue\';
import topicList from \'@/components/news/topic-list.vue\';
import userList from \'@/components/user-list/user-list.vue\';
export default {
components: {
commonList,
topicList,
userList
},
data() {
return {
searchText:"",
list:[\'uni-app第二季商城类实战开发\',\'uni-app第三季仿微信实战开发\',\'实战教程\',\'系列教程\'],
// 搜索结果
searchList:[],
// 当前搜索类型
type:"post"
}
},
// 监听导航输入
onNavigationBarSearchInputChanged(e){
this.searchText = e.text
},
// 监听点击导航搜索按钮
onNavigationBarButtonTap(e) {
if (e.index === 0) {
this.searchEvent()
}
},
onLoad(e) {
if (e.type) {
this.type = e.type
}
let pageTitle = \'帖子\'
switch (this.type){
case \'post\':
pageTitle = \'帖子\'
break;
case \'topic\':
pageTitle = \'话题\'
break;
case \'user\':
pageTitle = \'用户\'
break;
}
// 修改搜索占位
// #ifdef APP-PLUS
let currentWebview = this.$mp.page.$getAppWebview();
let tn = currentWebview.getStyle().titleNView;
tn.searchInput.placeholder = \'搜索\'+pageTitle;
currentWebview.setStyle({
titleNView: tn
})
// #endif
},
methods: {
// 点击搜索历史
clickSearchHistory(text){
this.searchText = text
this.searchEvent()
},
// 搜索事件
searchEvent(){
// 收起键盘
uni.hideKeyboard()
// 显示loading状态
uni.showLoading({
title: \'加载中...\',
mask: false
})
// 请求搜索
setTimeout(()=>{
switch (this.type){
case \'post\':
this.searchList = demo1
break;
case \'topic\':
this.searchList = demo2
break;
case \'user\':
this.searchList = demo3
break;
}
// 隐藏loading
uni.hideLoading()
},3000)
}
}
}
</script>
<style>
</style>