uniapp顶部导航栏实现自定义功能按钮+搜索框并监听响应事件

目录

第一步:先下载按钮需要展示的图标(若不使用图标,直接使用文字可跳过这步)

1、点击需要的图标,添加入库

2、点击旁边的购物车,在弹出的窗口中选择下载代码

3、解压下载的压缩包,将这几个iconfont文件复制出来

4、在uniapp项目的static文件夹下边创建一个font文件夹,将刚刚复制的文件放到这里边

第二步:自定义按钮

第三步:展示搜索输入框

*配置pages.json的完整实例(可直接复制使用):

第四步:设置自定义按钮的点击事件(在.vue文件中与methods同级)

第五步:监听原生标题栏搜索输入框输入内容变化事件(在.vue文件中与methods同级)


最终实现效果:

第一步:先下载按钮需要展示的图标(若不使用图标,直接使用文字可跳过这步)

到阿里图标库官网下载需要的字体图标:iconfont-阿里巴巴矢量图标库

1、点击需要的图标,添加入库

2、点击旁边的购物车,在弹出的窗口中选择下载代码

3、解压下载的压缩包,将这几个iconfont文件复制出来

4、在uniapp项目的static文件夹下边创建一个font文件夹,将刚刚复制的文件放到这里边

第二步:自定义按钮

更改pages.json下指定界面的style属性

点击这里可以查看uniapp中pages.json相关属性信息

这里主要需要配置app-plus属性,下边是相关的属性信息,导航主要需要配置titleNView属性

不需要字体图标的话可以直接在text中设置展示的文字内容 比如**"text":"提交"**

注意:如果使用字体图标,需要配置text和fontSrc这两个属性

text的设置:

在iconfont.css中找到需要设置的图标的content,在text中的写法必须是\u

复制代码
"text":"\ue607",

fontSrc设置读取ttf文件

复制代码
"fontSrc": "/static/font/iconfont.ttf",

buttons的完整代码设置

复制代码
"buttons":[
    {
        "text":"\ue607",
        "fontSrc": "/static/font/iconfont.ttf",
        "fontSize": "20px"
    },
    {
        "text":"\ue647",
        "fontSrc": "/static/font/iconfont.ttf",
        "fontSize": "24px"
    }
],

第三步:展示搜索输入框

和buttons同级配置searchInput属性

复制代码
"searchInput":{
    "placeholder":"查询",
    "align":"left",
    "backgroundColor":"#fff"
}

*配置pages.json的完整实例(可直接复制使用):

复制代码
{
    "path": "pages/zjgl/index",
    "style": {
        "navigationBarTitleText": "钻机管理",
        "app-plus":{
        "titleNView":{
        "buttons":[
            {
                "text":"\ue607",
                "fontSrc": "/static/font/iconfont.ttf",
                "fontSize": "20px"
            },
            {
                "text":"\ue647",
                "fontSrc": "/static/font/iconfont.ttf",
                "fontSize": "24px"
            }
        ],
        "searchInput":{
            "placeholder":"查询",
            "align":"left",
            "backgroundColor":"#fff"
        }
       }
     }
    }
},

第四步:设置自定义按钮的点击事件(在.vue文件中与methods同级)

监听远程标题栏按钮点击事件:onNavigationBarButtonTap

前台打印可以发现点击按钮获取到的信息

根据index属性进行监听设置按钮的功能

javascript 复制代码
onNavigationBarButtonTap:function(e){
    if(e.index == 0){
        //重新请求列表
        uni.$u.toast('界面刷新')
    }else if(e.index == 1){
        //新增信息
        uni.navigateTo({
            url:'/pages/sysy/tssy'
        })
    }
},

第五步:监听原生标题栏搜索输入框输入内容变化事件(在.vue文件中与methods同级)

输入框这里有三个方法,这里根据需求,我使用的是onNavigationBarSearchInputChanged方法,输入框内容变化就会请求数据刷新列表,这里各位根据需求进行使用即可。

javascript 复制代码
onNavigationBarSearchInputChanged(e){
    uni.$u.toast(e.text) //展示用户在输入框中输入的内容
},

至此,效果完美实现喽。

相关推荐
眸生15 分钟前
基于NeteaseCloudMusicApi的音乐app 支持 DeepSeek 自然语言找歌、批量导入歌单、下载音乐转换成MP3,下载歌词
android·python·kotlin·android studio·音频·fastapi·android jetpack
问心无愧051316 分钟前
ctf show web入门68,69
android·前端·笔记
码上有光26 分钟前
c++: 继承(下)
android·java·c++·多继承·菱形继承·虚继承
AI玫瑰助手31 分钟前
Python函数:可变参数(星号args与双星号kwargs)详解
android·开发语言·python
_李小白12 小时前
【android opencv学习笔记】Day 28: 滤波算法之中值滤波器
android·opencv·学习
代龙涛14 小时前
WordPress page.php 页面模板与自定义模板使用方法
android·开发语言·php
爱莉希雅&&&15 小时前
zabbix快速搭建和使用
android·linux·数据库·zabbix·监控
zfoo-framework17 小时前
理解kotlin limitedParallelism(1)与Actor模型
android·开发语言·kotlin
2401_8657213318 小时前
御网杯初赛2026
android
葱段19 小时前
【Compose】输入框(TextField)点击空白处失焦并关闭软键盘
android