微信小程序开发自定义tabBar实战案例(定制消息99+小红心)
作者:计算机魔术师 发布时间:2024-05-22 10:32:10
一、前提概要
效果:实现一个自定义tabBar,使消息tabBar能够显示消息数量,并通过全局共享的方式,控制消息数量
需要的知识点如下:
mobx辅助库(全局共享,见文章)
vant组件库(见文章)
组件的behavior (见文章)
自定义组件
样式隔离
组件数据 *
自定义组件主要分为三个步骤(许多实例实现步骤差不多流程)
配置信息 (几乎每个要实现的都需要这一步)
创建自定义组件代码文件
编写代码
详细步骤参考官方文档
注意:在配置自定义tabBar
时,app.json中
节点list不能删除,因为仍需要指定tabBar
页面,这是tabBar
的必要配置,但是这些字段不会影响自定义渲染。(如果低版本不生效,默认读取该字段渲染)
官方文档如是说
和默认tabBar一样,在app.json 中仅需要在tabBar节点设置( custom = true
设置为自定义),然后需要添加代码文件,
代码文件
custom-tab-bar/index.js
custom-tab-bar/index.json
custom-tab-bar/index.wxss
custom-tab-bar/index.wxml
我们创建根目录下custom-tab-bar
文件,点击生成component
(将其作为组件自定义,这与页面导航自定义是一样原理的)
效果如图:
此时系统自动识别该文件
接下来使用vant-weapp的组件库,对vant-weapp组件不了解的,
我们引入vant的tabBar标签组件
vant-weapp官方文档引入tabBar标签
复制代码,放入index.json文件中的components节点中(局部引入)
"usingComponents": {
"van-tabbar": "@vant/weapp/tabbar/index",
"van-tabbar-item": "@vant/weapp/tabbar-item/index"
}
按照官方文档,配置js文件的数据和方法,即可基本使用
效果:
接下来我们自定义图标,见官方文档:
还记得slot的用法吗,插槽
在对应的tabbar-item项中直接放入图片,通过插槽slot指定图片是选中状态还是未选中状态
在vant的tabbar组件源代码其实是有对于两个插槽接受图片的,如下:
<slot name="icon"></slot>
<slot name="icon-active"></slot>
源代码
<van-tabbar active="{{ active }}" bind:change="onChange">
<van-tabbar-item info="3">
<image
slot="icon"
src="{{ icon.normal }}"
mode="aspectFit"
style="width: 30px; height: 18px;"
/>
<image
slot="icon-active"
src="{{ icon.active }}"
mode="aspectFit"
style="width: 30px; height: 18px;"
/>
自定义
</van-tabbar-item>
<van-tabbar-item icon="search">标签</van-tabbar-item>
<van-tabbar-item icon="setting-o">标签</van-tabbar-item>
</van-tabbar>
Page({
data: {
active: 0,
icon: {
normal: 'https://img.yzcdn.cn/vant/user-inactive.png',
active: 'https://img.yzcdn.cn/vant/user-active.png',
},
},
onChange(event) {
this.setData({ active: event.detail });
},
});
我们往image
标签的属性src
放置我们图标即可
没有好的图标素材见:图标库素材
效果:
其中info是对改组件的传参,可以动态设定,不需要删掉即可
接下来我们循环生成图标,将我们第一个实例配置tabbar
的list
节点复制到index.js
的data
中,组件通过wx:for
循环list
数组,生成对应图标,
效果:
图片样式可以自己定义style
设置info的值可以在图标上显示 ,但是我们发现改图标会超出范围,如下图
原因很简单,是vant组件样式下有一个margin-bottom导致,我们可以通过设置vant组件的css全局变量设置
在通过外部样式修改组件的内部样式(样式隔离)之前,我们需要设定样式隔离
“styleIsolation”: "shared"
在父组件配置,修改配置
在index.js中
Component({
"options":{
"styleIsolation": "shared"
}
二、 动态显示info消息
如果未定义info则为假,不显示,如果为0也为假,也不显示符合我们的开发需求
使用mobx全局共享
思路:mobx绑定全局控制info
mobx官方文档
在index.js如下配置
// custom-tab-bar/index.js
import { storeBindingsBehavior } from 'mobx-miniprogram-bindings' //引入创建绑定实例
import { store } from '../store/store' // 引入仓库store
Component({
behaviors:[storeBindingsBehavior],
storeBindingsBehavior:[{
store,
fields:{
sum: 'sum'
},
actions:{
}
绑定sum的值到info
在一开始我是不知道如何同步sum和info的值,甚至想用 组件通信的知识解决(大家都知道组件通信很麻烦),
但是忘了组件有一个非常的方法:数据 * (behavior
)a
代码解释:
在以往赋值时是不需要对赋值对象加上双引号“”
的,
但是 list需要索引到 list[1] 由于模板语法需要双引号的形式'list[1].info' : a
效果如下
三、 页面切换效果
通过改组件自带的 事件绑定函数 onChange
解决 (通过其active
的变化使用编程式导航(文章介绍更新中)索引list
的url
路径切换页面
代码部分
methods: {
onChange(event) {
// event.detail 的值为当前选中项的索引
this.setData({
active: event.detail
});
wx.switchTab({
url: String(this.data.list[event.detail].pagePath), // String转换为字符串 或者加 "" 隐式转换, - 0 则隐式转换为整数
})
},
但是在设定好之后会出现如下情况,页面有正常跳转,但是图标却出了
bug
,其中active
在组件中是控制跳转到哪一个页面的,为0跳转到一个,为1跳转到第二个 ,在调试中,我发现active
的值没有毛病,按道理不应该出bug
,所以笔者认为应该是页面跳转时候,组件中的active
会变化,而js文件的active
没问题
解决方法:
将active 存贮到store 进行全局共享
添加字段和方法
在index.js文件中 修改onChnage函数
methods: {
onChange(event) {
// event.detail 的值为当前选中项的索引
this.updataActive(event.detail)
wx.switchTab({
url: String(this.data.list[event.detail].pagePath), // String转换为字符串 或者加 "" 隐式转换, - 0 则隐式转换为int
})
},
效果:
实现成功
修改标签颜色值
官方文档找到API
效果图:
四、 配置总结
其实我们都需要配置好
tabBar
的,不管是不是自定义都需要在app.json
的tarBar
节点配置,我们可以自定义配置文件可以tarBar
节点配置好完整属性,查看效果在细调,然后我们在创建自定义文件,编写代码,然后将我们刚刚配置的list节点放入custom-tab-bar
的index.js
的data
中在index.wxml
通过循环遍历改list数据实现效果,这种流程有几个好处
在版本不兼容时等一些特殊情况,还是能基本显示效果,
不用同时两处配置,在
app.json
节点配置list
复制到index.js
的data
,通过页面循环即可实现,且所循环数据都能很好满足数据需求,如图像链接,文本等
来源:https://blog.csdn.net/weixin_66526635/article/details/125227725
猜你喜欢
- 三遍记忆,让你记住海量素材的准确位置和用途,提高其可用性.这仅仅是一个示意图.在以往的日子里,我做到了只要脑袋里冒出一个想法,立刻就能知道我
- 在python开发的过程中,经常会遇到需要打印各种信息。海量的信息堆砌在控制台中,就会导致信息都混在一起,降低了重要信息的可读性。这时候,如
- 问题:连续或者单个窗体,如何打印当前显示的记录?当前窗体还有对应的子窗体,也要一起打印出来我在一个窗体里有一个单号,大子窗体里有几组数据,我
- Mysql数据库、数据库表、数据基础操作笔记分享给大家,供大家参考,具体内容如下一、数据库操作1.创建数据库Create dat
- 我们已对 Django1.6 app完成了数据库从mysql到PostgreSQL的迁移,如果你的环境很干净,这个过程就会很简单,只要允许s
- 一、re是什么?正则表达式是一个特殊的字符序列,能方便的检查一个字符串是否与某种模式匹配。re模块使得python拥有全部的正则表达式功能。
- Like中文解释为喜欢的意思,但当应用于MySQL数据库中,Like则是一种语句,用于模糊查询,主要是针对字符型字段的,在一个字符型字段列中
- 1.init 函数简介Golang init 函数是一种特殊的函数,主要用于完成程序的初始化工作,如初始化数据库的连接、载入本地配置文件、根
- 什么是JSON Web Token?JSON Web Token(JWT)是一个开放标准(RFC 7519),它定义了一种紧凑且自包含的方式
- 修改闭包内使用的外部变量错误示例:# 定义一个外部函数def func_out(num1): # 定义一个内部函数
- 目录图像翻转图像轮廓排序图像轮廓排序颜色识别基础颜色识别根据BGR获取HSV阈值编辑器图像翻转使用Python的一个包,imutils。使用
- 1、简述asp的6个内置对象和其功能答案 : session ,server ,response,request,objectcontext
- 前言最近接手了一个项目,由于之前为了快速开发,没有做代码检查。为了使得代码更加规范以及更易读,所以就要eslint上场了。安装依赖安装依赖有
- 近来,打开微信群发消息,就会秒收到一些活跃分子的回复,有的时候感觉对方回答很在理,但是有的时候发现对方的回答其实是驴唇不对马嘴,仔细深究发现
- 废话不多说了,直接给大家贴代码了。-- create functioncreate function [dbo].[fnXmlToJson]
- 目录一、pyecharts绘制饼图语法简介二、绘制普通饼图三、绘制圆环图四、绘制饼图-玫瑰图一、pyecharts绘制饼图语法简介饼图主要用
- 1.获取function形参个数functionName.length2.较适用的运算符delete:删除以前定义的对象属性或方法的引用vo
- MySql批量插入优化Sql执行效率实例详解itemcontractprice数量1万左右,每条itemcontractprice 插入5条
- 引言随着ES6新语法的不断迭代更新,已经出现了许多常用的工具api。今天我将为大家推荐两款明星api,它们就是Object.freeze和O
- 本文实例讲述了用python实现面向对像的ASP程序的方法。分享给大家供大家参考。具体实现方法如下:平时我们写ASP时,一般都用vbscri