微信小程序自定义胶囊样式
网络编程 2021-07-04 14:07www.168986.cn编程入门
这篇文章主要为大家详细介绍了微信小程序自定义胶囊样式,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了微信小程序自定义左上角胶囊样式的具体代码,供大家参考,具体内容如下
1、 将app.js 中的 window 对象属性navigationStyle 改为自定义
"window": { "navigationStyle": "custom" },
改完之后的效果:
2、获取 右上角胶囊的定位信息 设置
调用 wx.getMenuButtonBoundingClientRect() 函数得到右上角胶囊定位信息
所需要的 属性有 ,height属性,用于计算自定义左上角胶囊定位的位置
拿到 右上角胶囊的 和height 相加得到 屏幕导航栏的固定高度:
在 data函数中声明一个导航栏高度属性,和一个 胶囊具体定位的属性:
赋值导航栏的高度 数据:
// pages/testQ/index.js Page({ / 页面的初始数据 / data: { navHeight:0, capsuleTop: 0 }, / 生命周期函数--监听页面加载 / onLoad: function (options) { }, / 生命周期函数--监听页面初次渲染完成 / onReady: function () { }, / 生命周期函数--监听页面显示 / onShow: function () { let dwObj = wx.getMenuButtonBoundingClientRect() let navHeight_ = (dwObj. + dwObj.height) let capsuleTop_ = dwObj. this.setData( { navHeight: navHeight_, capsuleTop:capsuleTop_ } ) }, / 生命周期函数--监听页面隐藏 / onHide: function () { }, / 生命周期函数--监听页面卸载 / onUnload: function () { }, / 页面相关事件处理函数--监听用户下拉动作 / onPullDownRefresh: function () { }, / 页面上拉触底事件的处理函数 / onReachBottom: function () { }, / 用户点击右上角分享 / onShareAppMessage: function () { } })
在 wxml 中定义 导航栏:
<!--pages/testQ/index.wxml--> <!-- 左上角胶囊开始--> <!--left-capsule 是最上层,可以设置背景--> <view class="left-capsule"> <!--left-capsule-nav 是用于定位左上角的位置--> <view class="left-capsule-nav" style="height:{{navHeight}}px;"> <!--left-capsule-nav-content 是 胶囊主要内容--> <view style="position:relative;:{{capsuleTop}}px;" class="left-capsule-nav-content"> <!--back 胶囊 返回按钮--> <view class="back"> <!-- 我这个图标引入的是 vant库的icon,如果不是使用vant的话 得自定义一个icon--> <van-icon name="arrow-left" color="white" size="20"/> </view> <!-- line 胶囊 中间线条--> <view class="line"></view> <!-- home 胶囊 返回首页按钮--> <view class="home"> <!-- 我这个图标引入的是 vant库的icon,如果不是使用vant的话 得自定义一个icon--> <van-icon name="wap-home-o" color="white" size="20"/> </view> </view> </view> <!-- 以上 可以 封装成自定义组件,在引入,这个地方是 胶囊外的内容--> <view class="main-content" style=":{{navHeight}}px;"> 我是测试左上角胶囊 </view> <!-- 左上角胶囊结束--> </view>
wxss内容:
/ 导航栏css开始/ .left-capsule{ width: 100vh; height: 100vh; background-color: black; } .left-capsule .left-capsule-nav{ width: 100%; position: fixed; z-index: 2; } .left-capsule-nav .left-capsule-nav-content{ width: 85px; text-align: center; border-radius: 50px; position: relative; : 26px; left: 20px; box-shadow:0px 0px 1px 0.2px white; background-color: #1d19195c; height: 30px; } .left-capsule-nav-content view{ display: inline; width: 35px; position: relative; } .left-capsule-nav-content .back{ : 4px;left: -5px; } .left-capsule-nav-content .line{ : 3px; width: 1px; border-left: solid #cac3c3 thin; height: 17px; display: inline-block; } .left-capsule-nav-content .home{ : 4px; } / 导航栏css结束/ / 内容/ .main-content{ background-color: red; position: absolute; width: 100%; z-index: 1; }
效果图:
如果觉得红色地方太挨得进的话 在加大一点
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
上一篇:JavaScript代码实现简单计算器
下一篇:JS实现鼠标移动拖尾
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南