摘要:利用这篇教程存储一些常用的微信小程序开发技巧,方便查找。但是第一,微信小程序是国内的,有中文文档,虽然它的文档说明有点坑,但好歹有文档,阅读理解对小伙伴们来说不是问题。
Create by jsliang on 2018-9-17 17:58:56
Recently revised in 2018-11-19 08:19:13
Hello 小伙伴们,如果觉得本文还不错,记得给个 star , 你们的 star 是我学习的动力!GitHub 地址
写在前面 首个微信小程序实践记录:
工作量: PSD 18 张 (导出的 JPG 30 张)
耗时:12 个工作日
总结1: 在页面制作商,需要 3 周工作日(工作 15 天)搞定,前后端对接口另计。实际上,12 个工作日可以搞定所有页面,但是应该往前铺 1.5D 熟悉框架,往后铺 1.5D 整理代码。当然每个人的耗时可能不同,可根据个人实际情况进行调整。
总结2:在 API 调用上,根据接口数量可能需要 7-12 个工作日进行 API 调用,难点表现在: 1. 接口不够丰富,数据量不足; 2. 接口数据不够正式真实,跟前面的假数据相差太大; 3. 接口可能没法正常调用 等原因。故因根据小程序业务逻辑进行工作时长的报备。
这里有 jsliang 微信小程序开发中遇到的所有坑,以及在填坑过程中的一些个人经验。jsliang 利用这篇教程存储一些常用的微信小程序开发技巧,方便查找。它可能教不了你什么,但至少能省下你百度的功夫。
请结合 《目录》 和 《返回目录》 来进行跳转,获得更好的阅读体验。
本文技术支持:Ansen江
注1:由于更新频繁,有时候平台上的文章版本可能没有图片或者目录无法跳转,所以小伙伴需要获取最新资料的,请前往 GitHub:地址
注2:如果小伙伴使用的是手机版打开,那么推荐小伙伴使用电脑打开,因为各平台的手机端大都不支持页内跳转,看起来比较费劲。
目前已有 48 个坑。
请各位按目录检索时注意:
3.1、3.2、3.3…… 等二级目录对应着一个章节。
3.1.1、3.1.2、3.1.3…… 等三级目录将该二级目录这个大章节详细拆分成诸多小坑,方便查看。
注意!!!
由于 SF 可能有字数限制,故 章节 12.1 之后的内容需要小伙伴前往 GitHub 地址查看
GitHub 地址
目录 | 坑 |
---|---|
一 目录 | |
二 前言 | |
三 填坑实战 | |
3.1 swiper 轮播图 | 5 |
3.1.1 行内样式无效 | |
3.1.2 图片样式修改不了 | |
3.1.3 swiper 属性值设置 | |
3.1.4 轮播图图片跳转 | |
3.1.5 wx:key | |
3.1.6 实战代码 | |
3.2 tabBar 与 switchTab | 3 |
3.2.1 底部导航跳转 | |
3.2.2 自定义底部导航 | |
3.2.3 自定义组件 | |
3.3 px、rem 与 rpx | 1 |
3.4 微信 web 开发者工具 | 2 |
3.4.1 无法输入中文 | |
3.4.2 无法滑动滚轮 | |
3.5 组件与 API | 2 |
3.5.1 概念混淆:组件 VS API | |
3.5.2 API 查询不到对应的方法 | |
3.6 flex 布局 | 2 |
3.6.1 基础概念 | |
3.6.2 左右布局 | |
3.6.3 混合布局 | |
3.7 background-image 套用本地图片无效 | 1 |
3.8 |
1 |
3.9 搜索框 | 2 |
3.9.1 margin-top 无法上浮 | |
3.9.2 改造 WeUI 搜索框 | |
3.10 微信小程序分享 | 1 |
3.11 border-box 设置 | 1 |
3.12 自定义导航条 | 6 |
3.12.1 WeUI 选项卡 | |
3.12.2 自定义选项卡效果与实现 | |
3.12.3 绑定事件如何传递数据 | |
3.12.4 不允许驼峰 | |
3.12.5 获取 data 数据 | |
3.12.6 实现文字省略 | |
3.13 黑科技: |
2 |
3.13.1 被遗弃的 |
|
3.13.2 四种弹窗写法 | |
3.14 小程序解析 HTML | 6 |
3.14.1 解析 HTML 的三种方法 | |
3.14.2 wxParse | |
3.14.3 rich-text | |
3.14.4 web-view | |
3.15 诡异的 open-type | 1 |
3.16 | 1 |
3.17 下拉刷新和上拉加载 | 2 |
3.18 获取 input 的值 | 1 |
3.19 onLaunch 加载问题 | 2 |
3.19.1 小程序执行顺序 | |
3.19.2 路由守卫 | |
3.20 request 封装与 api 抽离 | 1 |
3.21 判断数据是否读取完 | 1 |
3.22 客服系统研究 | 1 |
3.23 文件在线预览 | 2 |
3.24 尽量使用 ES6 | 1 |
3.25 视频功能实现 | 1 |
返回目录
本文章原名【微信小程序 100 坑】
微信小程序的开发教程,或许写出来是非常受欢迎的。
但是:
第一,微信小程序是国内的,有中文文档,虽然它的文档说明有点坑,但好歹有文档,阅读理解对小伙伴们来说不是问题。
第二, jsliang 的文笔并没有想象中的那么好,想想如果我带你们走了一遍小程序开发,然后你们以为是一条平坦路,结果碰到一堆坑坑洼洼,咋办?最后的锅,会不会到我背啊,可怕!
所以,在这里, jsliang 结合 “日常躺坑” ,先为你解决小程序的 100 个坑!虽然现在可能还不够,但是第一天我就碰到 4/5 个了,我想我可以帮你们躺完 100 个的!!!
现在的微信开发者工具显示的开发版本是:"libVersion": "2.0.4"
如果你开发的版本已经解决了这个 bug ,或者你觉得这个 bug 还有其他解决方法,或者你觉得这个玩意还有其他 bug ,请告诉我,我会补充到这篇文档上,顺带记上您的大名,谢谢!
QQ: 1741020489
返回目录
这里的坑:
有的来源于微信自带的开发文档:小程序开发文档。在文档中,你会发现很多的乐趣!毕竟,你不知道什么时候中文成为了你的语言障碍~
有的是开发中遇到的,然后结合大量的百度结果,进行的有效性总结。
希望小伙伴在百度中或者无意看到这篇文章,请熟练使用浏览器的 Ctrl + F,查找需要的问题答案。
返回目录
本组件目前已有 5 个坑,有兴趣的小伙伴可以详看。
代码来源于该地址:微信组件 swiper 。
为方便小伙伴查看,下面贴出原版代码:
demo.wxml
interval duration
demo.js
Page({ data: { imgUrls: [ "http://img02.tooopen.com/images/20150928/tooopen_sy_143912755726.jpg", "http://img06.tooopen.com/images/20160818/tooopen_sy_175866434296.jpg", "http://img06.tooopen.com/images/20160818/tooopen_sy_175833047715.jpg" ], indicatorDots: false, autoplay: false, interval: 5000, duration: 1000 }, changeIndicatorDots: function(e) { this.setData({ indicatorDots: !this.data.indicatorDots }) }, changeAutoplay: function(e) { this.setData({ autoplay: !this.data.autoplay }) }, intervalChange: function(e) { this.setData({ interval: e.detail.value }) }, durationChange: function(e) { this.setData({ duration: e.detail.value }) } })
好的,上面就是微信官方文档的演示代码,如果你跟着演示代码走了一遍碰到疑问的话,看看这里我挖的土是不是能填好你的坑:
返回目录
demo.wxml 中出现的
返回目录
在任何出现图片的地方(包括但不限于轮播图),如果你发现不仅行内写法无效之外,还发现单纯地给图片加 class,去 *.wxss 写样式也无效的话。那么,我建议小伙伴最好采用样式加重法,即 .image-wrap .image 这种写法格式,来确保图片样式能进行修改。详细用法可看下文。
返回目录
swiper 属性值。官方文档说明:
虽然,它的属性名和属性值是这么说的。但是,用的时候,首先你需要在 demo.wxml 中的 swiper 绑定这个属性名,然后在 demo.js 中设置其属性值。值得注意的是,它的绑定值,稍微不同于 Vue, 需要设置 {{}} 形式。如果文字描述你看得不是很清楚,可以参照下面的代码进行理解。
返回目录
关于轮播图的地址跳转,在微信小程序的官网是没用提及的,也是 jsliang 去百度查看了下,才知道怎么设置(可能是我一开始就挑战的难度太高了么 -_-|| ),在下面 jsliang 贴出来代码~想知道怎么解决的可以去看看:首先,在 data 中设置 link ;然后,设置 navigator 导航遍历 item.link 。
返回目录
关于 wx:key , wx:key 的作用是:当数据改变触发渲染层重新渲染的时候,会校正带有 key 的组件,框架会确保他们被重新排序,而不是重新创建,以确保使组件保持自身的状态,并且提高列表渲染时的效率。但是,在其 swiper 中,小程序本身是没有写的,所以它会带有 warning ,这里也是个小坑, jsliang 也是百度了下也知道这件事:点我了解。
返回目录
下面给出这 5 个坑的解决代码,如有不对,尽情指出:
index.wxml
index.wxss
.carousel .slide-image { width: 100%; height: 420rpx; }
index.js
Page({ data: { imgUrls: [ { link: "../index/index", url: "http://img02.tooopen.com/images/20150928/tooopen_sy_143912755726.jpg", }, { link: "../demo/demo", url: "http://img06.tooopen.com/images/20160818/tooopen_sy_175866434296.jpg", }, { link: "../logs/logs", url: "http://img02.tooopen.com/images/20150928/tooopen_sy_143912755726.jpg" } ], indicatorDots: true, autoplay: true, interval: 5000, duration: 1000 } })
返回目录
本组件目前已有 3 个坑,有兴趣的小伙伴可以详看。
tabBar :底部菜单栏,需要在 app.json 中设置。使用方法:见下文。
navigator :导航切换。使用方法:地址
switchTab :控制 tabBar 的切换。使用方法:地址
返回目录
在这里,我们讲下 tabBar 的坑,如果你在 app.json 中设置了 tabBar :
app.json
"tabBar": { "list": [{ "pagePath": "pages/index/index", "text": "首页", "iconPath": "./public/index_tabBar1_nor.png", "selectedIconPath": "./public/index_tabBar1.png" }, { "pagePath": "pages/demo/demo", "text": "发现", "iconPath": "./public/index_tabBar2_nor.png", "selectedIconPath": "./public/index_tabBar2.png" }, { "pagePath": "pages/logs/logs", "text": "我的", "iconPath": "./public/index_tabBar3_nor.png", "selectedIconPath": "./public/index_tabBar3.png" }] }
那么,我们就需要通过设置 switchTab 来控制底部导航的跳转,而不能通过 navigator 来跳转:
demo.wxml
demo.js
linkTo: function () { wx.switchTab({ url: "../index/index" }); },
返回目录
那么问题又来了,当我们切换到子页面的时候,我们发现 tabBar 这个底部导航栏不见了,然后问了下 Ansen江 ,他说之前是整个小程序都有的,有些页面还要想方设法去隐藏。
但是现在嘛……它没了!没了啊!!!在微信小程序的文档没看到有唤起底部导航条的方法,难道我要做一个导航条了么 -_-||
回答是:yes!
所以,下面给出该底部导航条 tabBar 的实现情况和代码片段:
注:图片宽高均为 54rpx*.wxml
首页 在线咨询 电话咨询 立即订购
*.wxss
.nav { display: flex; justify-content: space-around; font-size: 20rpx; border: 1px solid #ccc; position: fixed; bottom: 0; background: #fff; } .nav view { display: flex; flex-direction: column; align-items: center; } .nav image { width: 54rpx; height: 54rpx; } .nav text { margin-top: 7rpx; } .nav-home { border-right: 1px solid #ccc; width: 130rpx; padding-top: 5rpx; } .nav-service { border-right: 1px solid #ccc; width: 130rpx; padding-top: 5rpx; } .nav-phone { width: 130rpx; padding-top: 5rpx; } .nav-buy { background: #eb333e; color: #fff; width: 360rpx; height: 98rpx; line-height: 80rpx; font-size: 34rpx; }
*.js
callWaiter: function(res) { wx.makePhoneCall({ phoneNumber: "13264862250", success: function(res) { console.log("拨打成功"); console.log(res); }, fail: function(res) { console.log("拨打失败"); console.log(res); }, complete: function(res) { console.log("拨打完成"); console.log(res); } }) }, goHome: function() { wx.switchTab({ url: "../index/index" }) },
返回目录
在最近的工作中,又发现一个小问题:
像这个导航条,它需要根据页面所在的模块,动态地展示不同位置的状态为活跃,而且它是需要在多个页面重复出现的,如果每个页面我都要复制粘贴一遍,到时候要修改起来的时候,麻烦不说,最重要的是,它可能影响我前端的性能了,能不能直接将其封装起来呢?
自定义组件:链接
是的,发现在小程序文档中是存在这个东西的。当然,至于过程中我百度了几篇文章来辅助写出下面的代码,你猜?
子组件写法
navBar.wxml
首页 发现 我的
navBar.wxss
/* 底部导航条 */ .navBar { width: 100%; padding: 18rpx 0; border-top: 1rpx solid #cccccc; display: flex; justify-content: space-around; position: fixed; bottom: 0; background: #fff; } .navBar image { width: 55rpx; height: 55rpx; } .navBar view { display: flex; flex-direction: column; align-items: center; font-size: 20rpx; color: #999999; } .navBar-user text { color: #d0a763; }
navBar.js
// pages/componentNavBar/navBar.js Component({ /** * 组件的属性列表 */ properties: { homeActive: { type: Boolean, value: false }, exploreActive: { type: Boolean, value: false }, userActive: { type: Boolean, value: false } }, /** * 组件的初始数据 */ data: { }, /** * 组件的方法列表 */ methods: { // 返回首页 goHome: function (e) { wx.switchTab({ url: "../index/index", }) }, // 返回发现页 goExplore: function (e) { wx.switchTab({ url: "../explore/explore", }) }, // 返回我的页面 goUser: function (e) { wx.switchTab({ url: "../user/user", }) }, showCode: function(e) { console.log(e); let that = this; console.log(that.data); } } })
navBar.json
{ "component": true, "usingComponents": {} }
然后,在父组件的使用,只需要:
*.wxml
*.json
{ "usingComponents": { "navBar": "../componentNavBar/navBar" } }
*.js
data: { userActive: true },
怎样?这就是自定义组件的写法,是不是觉得特好用涅,一次写完,终身受用。
返回目录
本节目前已有1个坑,有兴趣的小伙伴可以详看。
在微信中,它自带了一套属于自己的单位:rpx , rpx 不同于之前我们认识的 px 、 rem 、 em ,如果你的设计稿是 750 px 的,那么很容易的, 1px = 1rpx ,但是,如果设计稿不是 750 px ,那么将造成一个 bug ,至于这个 bug 如何解决……
-_-|| 谁知道呢……要不先把UI设计师宰了?
知识补充:关于 rpx 。
返回目录
本节目前已有 2 个坑,有兴趣的小伙伴可以详看。
返回目录
如果你在开发过程中,发现只能写英文了,而中文无法输入了,千万别急,也别怪输入法出 bug 了,你只需要:重启开发工具。
返回目录
如果你某时刻,突然发现你没法滚动代码进行查看,而是需要拖动滚动条才行,请别怪你的鼠标,你可以去浏览器打开一篇文章看看,enm...你的鼠标还是好的~所以,请:重启开发工具。
返回目录
本节目前已有 2 个坑,有兴趣的小伙伴可以详看。3.5.1 概念混淆:组件 VS API
返回目录
首先,科普下 组件 与 API 是什么:
组件:对数据和方法的封装,使用组件可以实现拖放式编程、快速的属性处理以及真正的面向对象的设计【百度百科】。那么,可以理解为:开发中常用的一些部件,我们都可以封装起来,然后在需要的时候拿来用,即为组件。
API:预先定义的函数,提供应用程序与开发人员无需访问源码,基于某软件或硬件得以访问一组例程的能力【百度百科】。就是说已经写好的一些 Function 或者后端接口,前端直接调用就行了。
但是,在微信小程序官方文档中,组件与API,拆分地有点不科学。
例如:轮播图与底部导航条
一个在组件中,一个在 API 中;
一个在 wxml 、 wxss 、 js 中要设置对应的参数,一个只需要在 app.json 中设置就行。
可能微信小程序考虑到底部导航条不应该有太大的变化(例如让你修改太多样式或者 js ),所以将导航条内嵌至源码中了。
但是,这可能导致什么重要影响吗?是的,如果底部导航条需要进行修改呢?例如:3.2.3 自定义组件。这样的情况下,我们的开发时间就有所增加了。
返回目录
如果小伙伴你经常有去看微信小程序官方文档的话,那么你一定会有一件事需要吐槽,那就是:
明明上次我见到过某个 API 实现了我需要做的功能,但是改天我回去查找的时候,它却提示我没有这个玩意,这是什么鬼?!
是的,跟我们 3.13 黑科技:
返回目录
本节目前已有 3 个坑,有兴趣的小伙伴可以详看。
Flex布局又称弹性布局,在小程序开发中比较适用。但是由于 jsliang 之前没怎么用过 Flex 布局,所以在这里咱们特意去踩下坑,充实下自己。【小程序开发之页面布局】【阮一峰-Flex 布局教程】
在我们布局页面的时候,最好看看 阮一峰 的教程,平时遇到布局的问题的时候,我都习惯去上面 阮一峰 的文章看看:
返回目录
基础概念:地址
display: flex; flex-direction: row | row-reverse | column | column-reverse; flex-wrap: nowrap | wrap | wrap-reverse; flex-flow:|| ; justify-content: flex-start | flex-end | center | space-between | space-around; align-items: flex-start | flex-end | center | stretch | baseline; align-content: flex-start | flex-end | center | space-between | space-around | stretch;
返回目录
实现效果如下:
如图,这是我们要实现的左右布局效果。那么,在微信小程序要怎么做呢?
*.wxml
热门推荐 查看全部 >
*.wxss
.top-recommended-headlines { display: flex; align-items: flex-end; height: 31rpx; line-height: 31rpx; margin-bottom: 10rpx; } .top-recommended-headlines-left text { font-size: 32rpx; font-weight: bold; } .top-recommended-headlines image { width: 366rpx; height: 31rpx; margin-left: 10rpx; } .top-recommended-headlines-right navigator { font-size: 26rpx; color: #a9a9a9; margin-left: 50rpx; }
返回目录
实现效果如下:
如图,这是我们要实现的左右布局效果。那么,在微信小程序要怎么做呢?
*.wxml
{{item.title}} {{item.content}} {{item.datatime}} {{item.reader}}阅读 #{{item.label}}#
*.wxss
.weui-tab__content-item3 { padding-left: 30rpx; padding-right: 30rpx; margin-top: -10rpx; margin-bottom: 10rpx; } .weui-tab__content-item3:first-child { padding: 40rpx 30rpx 0; } .weui-tab__content-item3-question image { width: 30rpx; height: 30rpx; } .weui-tab__content-item3-question text { font-size: 30rpx; line-height: 46rpx; font-weight: bold; color: #333; margin-left: 10rpx; } .weui-tab__content-item3-answer image { width: 30rpx; height: 30rpx; } .weui-tab__content-item3-answer text { font-size: 26rpx; line-height: 42rpx; color: #a9a9a9; margin-left: 10rpx; } .weui-tab__content-item3-detail { display: flex; justify-content: space-between; font-size: 26rpx; color: #a9a9a9; } .weui-tab__content-item3-detail-label { color: #d0a763; } .weui-tab__content-item3-gap image { width: 100%; height: 30rpx; }
*.js
tabs3Content: [ { title: "员工发明创造是否属于职务发明的认证标准?", content: "随着企业对知识产权在企业发展中核心竞争力的认识力提高,企业保护自身知识产权的意识不断增强,使其技术得......", datatime: "2018-03-05", reader: "2081", label: "知识产权" } ]
返回目录
本节目前已有 1 个坑,有兴趣的小伙伴可以详看。
在小程序中,如果你使用 wxss,你是可以发现有 background-image 的提示的。但是,如果你设置它的背景图是本地图片,你会发现,它是不生效的。
解决方案:
在使用背景图片的时候用网络图片,就是用外链的形式,比如你将这张图片放到你的服务器,如:https://xxxx/xxx.jpg;
将背景图片使用编码base64进行转换,可以在这个网址进行 点我前往 转换,如:background-image: url("转换后得到的编码文本"),如果多次使用的话可以将该值设置为全局变量,再在js文件进行引用即可。
使用 image 组件 + position 定位而不是使用 background-image 。
返回目录
本节目前已有 1 个坑,有兴趣的小伙伴可以详看。
两者的区别是,
所以,如果你仅仅是需要包裹,而不是渲染一个层,可以使用
返回目录
本节目前已有 2 个坑,有兴趣的小伙伴可以详看。
返回目录
首先,我们要实现的效果是:
然后, jsliang 的想法是:
*.wxml
*.wxss
.search { height: 100rpx; display: flex; flex-direction: column; justify-content: space-between; align-items: center; position: relative; } .search-product-input { background: #f5f5f5; width: 650rpx; height: 65rpx; border-radius: 30rpx; font-size: 30rpx; padding-left: 20rpx; } .search-placeholder { font-size: 26rpx; text-align: center; margin-top: -65rpx; z-index: 2; } .search-placeholder-icon { width: 24rpx; height: 24rpx; } .search-placeholder-text { margin-left: 10rpx; }
你注意到了吗?在 *.wxml 中, jsliang 设置了个空的
好吧,可能有其他的实现方式,但是如果你下次使用这种方式,注意上面这个坑~
返回目录
回头看了下 WeUI 的实现方式,发现跟我的思路是挺像的,关于 input 的实现方式,现在依据 WeUI ,成功实现了输入框:
源码奉上:
*.wxml
取消 搜索
*.js
Page({ data: { inputShowed: false, inputVal: "" }, showInput: function () { this.setData({ inputShowed: true }); }, hideInput: function () { this.setData({ inputVal: "", inputShowed: false }); }, clearInput: function () { this.setData({ inputVal: "" }); }, inputTyping: function (e) { this.setData({ inputVal: e.detail.value }); } })
*.wxss
.search { height: 100rpx; padding: 18rpx 30rpx; } .weui-search-bar { padding: 0; background-color: #fff; border-top: none; border-bottom: none; height: 64rpx; } .weui-search-bar__form { border: none; } .form-border { border: 1rpx solid #f5f5f5; background: #f5f5f5; } .weui-search-bar__label { background: #f5f5f5; border-radius: 30rpx; } .weui-search-bar__cancel-btn { font-size: 26rpx; background: rgb(8, 202, 186); color: #fff; padding: 2rpx 20rpx 0 20rpx; border-radius: 10rpx; } .weui-search-bar__submit-btn { font-size: 26rpx; background: rgb(8, 200, 248); color: #fff; padding: 10rpx 20rpx 0 20rpx; border-radius: 10rpx; }
返回目录
本节目前已有 1 个坑,有兴趣的小伙伴可以详看。
官方文档:地址
在这里,提醒广大小伙伴注意了,注意了,注意了!重要的事说三遍。
当你新建 page 的时候,微信 web 开发者工具会自动帮你添加分享事件:
/** * 用户点击右上角分享 */ onShareAppMessage: function (res) { // 实现分享功能 return { title: this.data.productName, path: "/pages/indexProductDetail.js?productId=" + this.data.productId, imageUrl: this.data.videoImageSrc, success: (res) => { console.log("分享成功~"); }, fail: (res) => { console.log("分享失败~"); } } }
所以,如果你在前面定义了,它会在最下面偷偷帮你清空,然后你就觉得无法自定义分享事件……
是的,jsliang 打死都不承认这是我自己的锅,新手注意!新手注意!!新手注意!!!
返回目录
本节目前已有 1 个坑,有兴趣的小伙伴可以详看。
熟知盒模型的小伙伴应该知道,盒模型有两种计算方式:
box-sizing: border-box;
box-sizing: content-box;
在 border-box 中,整个 view 的宽、高,包括 margin、padding、border。
而在 content-box 中,整个 view 的宽、高,则不包括上面元素。
如上图,如果一个 view ,你的代码如下:
view { box-sizing: border-box; margin: 10rpx; width: 100rpx; height: 100rpx; padding: 10rpx; }
那么,你的整个宽高还是 100rpx。
但是,如果你的代码如下:
view { box-sizing: content-box; margin: 10rpx; width: 100rpx; height: 100rpx; padding: 10rpx; }
那么,你的整个盒子宽高是 120rpx。
如果你在设计页面中,发现内容区被撑爆了,那么,请检查下现在的 border-box 是什么。
返回目录
本节目前已有 6 个坑,有兴趣的小伙伴可以详看。
返回目录
使用 WeUI 的导航条,首先需要引用 WeUI 的 CSS 样式:地址
下载 weui.wxss 并在 app.wxss 中引用即可
app.wxss
/* 引用WeUI */ @import "weui.wxss";
然后,我们直接往页面加入它的选项卡并根据项目需求修改其样式:
*.wxml
{{item}} 全部 已付款 待付款
*.wxss
.tab { font-size: 26rpx; } .tab image { width: 173rpx; height: 29rpx; } .weui-navbar { border-top: 1rpx solid #efefef; border-bottom: 1rpx solid #efefef; } .weui-navbar__slider { background: #d0a763; width: 4em; } .weui-navbar__item.weui-bar__item_on { color: #d0a763; } .weui-tab__content { margin-bottom: 100rpx; }
*.js
var sliderWidth = 52; // 需要设置slider的宽度,用于计算中间位置 Page({ /** * 页面的初始数据 */ data: { // 选项卡导航 tabs: ["全部", "已付款", "待付款"], activeIndex: 1, sliderOffset: 0, sliderLeft: 0, }, // 选项卡切换 tabClick: function (e) { this.setData({ sliderOffset: e.currentTarget.offsetLeft, activeIndex: e.currentTarget.id }); }, /** * 生命周期函数--监听页面加载 */ onLoad: function (options) { // 计算搜索框活跃条 var that = this; wx.getSystemInfo({ success: function (res) { that.setData({ sliderLeft: (res.windowWidth / that.data.tabs.length - sliderWidth) / 2, sliderOffset: res.windowWidth / that.data.tabs.length * that.data.activeIndex }); } }); } })
2018-11-15:新增一个 bug 修复,就是在第一个 tab 能流畅切换的情况下,第二个及其他的 tab,需要多次滑动才能上拉加载。这时候,只需要在 weui-tab__content 这个类新增三行代码就可以解决该问题:
*.css
.weui-tab__content { padding: 30rpx 30rpx 0; box-sizing: border-box; height: 100%; overflow: hidden; }
返回目录
自定义选项卡的代码实现:
实现效果图如下:
实现代码如下:
*.wxml
{{item.label}} {{item.title}} 发布时间:{{item.datatime}} 生效时间:{{item.effectiveTime}}
*.wxss
.weui-tab__nav { background: #f5f5f5; border: 1rpx 0rpx solid #e6e6e6; height: 90rpx; padding: 17rpx 41rpx; display: flex; justify-content: space-between; } .weui-tab__nav text { border-radius: 56rpx; height: 56rpx; line-height: 56rpx; padding: 15rpx 23rpx; font-size: 26rpx; font-weight: bold; } .weui-tab__nav-active { color: #fefefe; background: #d0a763; } .weui-tab__content-item2 { display: flex; justify-content: space-between; padding: 25rpx 30rpx; } .weui-tab__content-item-descritpion { display: flex; justify-content: space-between; } .weui-tab__content-item-descritpion image { width: 60rpx; height: 70rpx; } .hide { display: none; } .weui-tab__content-item-descritpion-content { margin-left: 26rpx; } .weui-tab__content-item-descritpion-content-title { font-size: 28rpx; font-weight: bold; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; } .weui-tab__content-item-descritpion-content-datatime { font-size: 22rpx; color: #bbb; } .weui-tab__content-item-descritpion-content-datatime1 { margin-right: 35rpx; } .weui-tab__content-item-download-state image { width: 64rpx; height: 64rpx; }
*.js
data: { tabs2Nav: [ { id: "1", label: "法律大全", state: 1 }, { id: "2", label: "合同模板", state: 0 }, { id: "3", label: "民事", state: 0 }, { id: "4", label: "行政", state: 0 }, { id: "5", label: "执行", state: 0 } ], tabs2Content: [ { title: "中华人名共和国民用航空法(2015年...).doc", url: "https://wxmcard.imusic.cn/testfordocdownload.doc", datatime: "2018-01-26", effectiveTime: "2018-01-26", type: "1" }, { title: "原生申诉表格.xls", url: "https://wxmcard.imusic.cn/testfordocdownload.doc", datatime: "2018-01-26", type: "2" }, { title: "法律常识大汇集及范例.ppt", url: "https://wxmcard.imusic.cn/testforpptdownload.pptx", datatime: "2018-01-26", effectiveTime: "2018-01-26", type: "3" }, { title: "事业单位法律基础知识总结.pdf", url: "https://wxmcard.imusic.cn/testforpdfdownload.pdf", datatime: "2018-01-26", effectiveTime: "2018-01-26", type: "4" } ], // 选项卡第二屏分组 tabs2Content1: [ { title: "中华人名共和国民用航空法(2015年...).doc", datatime: "2018-01-26", effectiveTime: "2018-01-26", type: "1" }, { title: "原生申诉表格.xls", datatime: "2018-01-26", type: "2" }, { title: "法律常识大汇集及范例.ppt", datatime: "2018-01-26", effectiveTime: "2018-01-26", type: "3" }, { title: "事业单位法律基础知识总结.pdf", datatime: "2018-01-26", effectiveTime: "2018-01-26", type: "4" } ], tabs2Content2: [ { title: "合同模板.doc", datatime: "2018-01-26", effectiveTime: "2018-01-26", type: "1" } ], tabs2Content3: [ { title: "民事合同模板.doc", datatime: "2018-01-26", effectiveTime: "2018-01-26", type: "1" } ], tabs2Content4: [ { title: "行政合同模板.doc", datatime: "2018-01-26", effectiveTime: "2018-01-26", type: "1" } ], tabs2Content5: [ { title: "执行合同模板.doc", datatime: "2018-01-26", effectiveTime: "2018-01-26", type: "1" } ] }, // 选项卡2切换 tabs2NavClick: function(e) { var that = this; console.log("完整的数据是:"); console.log(that.data.tabs2Nav); console.log("点击的标签是:"); console.log(e.currentTarget.dataset.labelid); var newTabs2Content; console.log("正在经历的标签是:"); for(var i=0; i注意 由于 SF 可能有字数限制,故 章节 12.1 之后的内容需要小伙伴前往 GitHub 地址查看
GitHub 地址
jsliang 的文档库 由 梁峻荣 采用 知识共享 署名-非商业性使用-相同方式共享 4.0 国际 许可协议进行许可。
基于https://github.com/LiangJunro...上的作品创作。
本许可协议授权之外的使用权限可以从 https://creativecommons.org/l... 处获得。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/114243.html
摘要:利用这篇教程存储一些常用的微信小程序开发技巧,方便查找。但是第一,微信小程序是国内的,有中文文档,虽然它的文档说明有点坑,但好歹有文档,阅读理解对小伙伴们来说不是问题。 Create by jsliang on 2018-9-17 17:58:56 Recently revised in 2018-11-19 08:19:13 Hello 小伙伴们,如果觉得本文还不错,记得给个...
摘要:利用这篇教程存储一些常用的微信小程序开发技巧,方便查找。但是第一,微信小程序是国内的,有中文文档,虽然它的文档说明有点坑,但好歹有文档,阅读理解对小伙伴们来说不是问题。 Create by jsliang on 2018-9-17 17:58:56 Recently revised in 2018-11-19 08:19:13 Hello 小伙伴们,如果觉得本文还不错,记得给个...
摘要:顺便补充一句,微信官方提供的判断依旧不全面,最新出来的苹果手机还没有完全支持相关的坑可以在官方社区的问答中找到。 首次在这里写点东西,还请各位大佬担待点。 摘要:昨天的placeholder-class只是希望各位看官注意,而今天的textarea就绝对是一个超级大坑!而且如果看官手中没有苹果手机测试的话,这个可就真的是个坑了!为啥?难道要等到用户向你反馈你们产品有bug???.......
阅读 2887·2021-11-17 09:33
阅读 1584·2021-10-12 10:13
阅读 2338·2021-09-22 15:48
阅读 2190·2019-08-29 17:19
阅读 2571·2019-08-26 11:50
阅读 1538·2019-08-26 10:37
阅读 1715·2019-08-23 16:54
阅读 2900·2019-08-23 14:14