微信小程序开发笔记(四)UI 续

本篇接微信小程序开发笔记(三),这里主要是来实现几种常见的效果,增强对微信小程序UI的理解和使用。篇幅有点长 可根据需要 只看123中的任意一个

1)购物车列表 左滑删除商品

尽管我个人不喜欢左滑右滑来删除,但是UI小哥哥设计的是这样的功能,so, 开心就好,撸起袖子,就是干!先上一张效果图


image.png

首先滑动删除,肯定就想到了<scroll-view/> 控制横向滑动就好了,难道真的这么简单,哈哈哈,是的,就这么简单,在列表view最外层加一层<scroll-view/>,需要注意的是,微信小程序默认宽度750rpx,所以内容控制在750rpx,然后删除按钮的大小可设置一个固定值,这样好控制<scroll-view/>的宽度,这里用的是150rpx,所以<scroll-view/>的宽度固定为了900rpx,然后绑定删除事件就可以了。发现,删除第一个商品后,第二个就自动显示删除按钮,然后发现<scroll-view/> 的这个scroll-into-view属性,可以滚动到某个设置id的view的位置,于是给列表view 设置id,在完成删除操作后,让view 滚动到该id的位置就可以啦。至此,搞定购物车删除功能。
未命名文件.png

部分代码:
wxml

 <scroll-view scroll-x scroll-into-view="{{toView}}">
    <!--id 为了删除后 控制view 滚动到初始位置 -->
      <view id='scroll-before' class='flex-row white-bg w900'>
      <view >item布局 此处省略</view>
      <view class='scroll-del' bindtap='tapDrop' data-id='{{index}}'>删除</view>
      </view>
      </scroll-view>

js

// 删除之后 回滚到初始状态
      let toView = 'scroll-before'
      that.setData({
        toView: toView
      })

wxss

/** 去掉scroll-view的滚动条 ,如果多个不同用途的scroll-view ,则所有的都不显示滚动条 **/
::-webkit-scrollbar {
width: 0;
height: 0;
color: transparent;
}

这样的做法的一个弊端就是,如果用户滑动后没有删除操作,继续加载数据的时候,这个滑动到一半的状态依然存在,并不会回滚到初始状态。

2)tabBar效果

微信小程序 自己提供了tabBar,在app.json中进行配置tabBar即可,点击[微信小程序全局配置]查看详情,效果图如下

image.png

这里不介绍官方的这个,看文档就可以了,没必要看我的这些废话了撒。

首先实现一个顶部tabBar,效果图:


image.png

wxml:其实就是水平放置了一个view,循环取出tab上的内容,会发现这里用的是<view/>而不是<scroll-view/> 所以当内容过多的时候会出现拥挤的情况,如果内容过多 可以考虑使用<scroll-view/>,让后就是选中和没选中两种状态的判断,显示不同的view

<view class='top-tab'>
  <block wx:for='{{tabs}}' wx:for-index="index" wx:key='tabs'>
    <view wx:if='{{item.isSel}}' class='tab-navigation-bar padding-l20 padding-r20  padding-b20 font34 selcted' data-id='{{index}}' bindtap='tapTab'>
    <text class='selected'>{{item.text}}</text>
    </view>
     <view wx:else class='tab-navigation-bar padding-l20 padding-r20  padding-b20 font34' data-id='{{index}}' bindtap='tapTab'>
    <text>{{item.text}}</text>
    </view>
  </block>
</view>

wxss: 把总体的tab固定在屏幕顶部,然后就是选中和未选中的两种状态。选中的时候 下面画了一条线,改变了文字的颜色

.top-tab {
  display: flex;
  flex-direction: row;
  justify-content: space-evenly;
  padding-top: 20rpx;
  padding-bottom: 20rpx;
}

.tab-navigation-bar {
  color: #333;
  font-size: 28rpx;
}

.tab-navigation-bar .selected {
  border-bottom: 8rpx solid #fa6e57;
  padding-bottom: 10rpx;
  color: #fa6e57;
  font-size: 28rpx;

}

js,当点击时改变切换状态

/**
   * 切换tab
   */
  tapTab:function(e){
    let that = this

    var idx = e.currentTarget.dataset.id
    var tabs = that.data.tabs

    // 设置选中的效果
    tabs.map(function(item,index,arr){
      if(index === idx){
        item.isSel = true
      }else{
        item.isSel = false
      }
    })

    that.setData({
      tabs:tabs
    })

其实写下来发现是不是还挺简单的,等等,你以为我只想要这个切换的效果,下面的数据怎么办,不同的tab对应不同的内容吧,内容有列表有瀑布流还有设计师想象的各种页面,OK,继续,我们知道可以通过if或者hidden,控制view的显示和隐藏,这下立马就懂了吧,我们定义一个变量用来记录当前页面的索引,切换时实时更新变量的值就可以实现不同的页面展示效果了,想要什么样就有什么样。

if 是否渲染条件块内的模版,会触发局部渲染以确保条件块,在切换时销毁或重新渲染。如果初始渲染条件是false 则框架什么也不做
hidden组件始终都会被渲染,只是简单控制隐藏与显示,并不会触发重新渲染和销毁
如果状态频繁切换则使用hidden,否则使用if

所以这里用hidden。通过curNav控制当前显示的就可以了,然后 在js中更新即可

<view hidden='{{curNav != 0}}'>
  hahaha 测试第一个view
  </view>

   <view hidden='{{curNav != 1}}'>
  hahaha 测试第二个view
  </view>

   <view hidden='{{curNav != 2}}'>
  hahaha 测试第三个view
  </view>

   <view hidden='{{curNav != 3}}'>
  hahaha 测试第四个view
  </view>

   <view hidden='{{curNav != 4}}'>
  hahaha 测试第五个view
  </view>
 that.setData({
      tabs:tabs,
      curNav:idx,
    })

如果UI都是一样的,那么就不用这么写啦,只需要在加载数据的时候控制就可以了.

3)列表处理

效果图 如下


image.png

刚开始做这种类似gridview效果的时候,感觉还挺麻烦的,后来系统看了一遍css相关属性,发现可通过flex布局的 flex-wrap 来控制 内容是否换行显示,这样就容易处理的多啦,并且还可以逆序显示,可根据需要进行展示。

列表循环for循环的使用,wx:for-item 可以指定数组当前元素的变量名,wx:for-index 可以指定数组当前下标的变量名, 可在子view上通过data-id来绑定数据,一般绑定的是下标,也可以绑定某个数组的值,很实用,可在js中通过 e.currentTarget.dataset.id获取绑定的值

  <view class='grid margin-t20'>
    <block wx:for="{{lists}}" wx:key="lists" wx:for-item='item' wx:for-index='index'>
      <view class='grid-item'>
        <image src='{{item.img}}' mode='widthFix' class='fillet' data-id='{{index}}' bindtap='tapImg'></image>
        <text class='c-333 font32 txt' data-id='{{item}}' bindtap='tapTxt'>{{item.title}}</text>
        <text class='c-999 font24'>{{item.desc}}</text>
      </view>
    </block>
  </view>

分别点击图片和文字,则打印对应的下标 和 数组中该元素的值


image.png

嗯呢,到这里就写完了,希望对你有帮助,谢谢。愿我们年少有为!!

微信小程序开发系列笔记:
微信小程序开发笔记(三)
微信小程序开发笔记(二)
微信小程序开发笔记(一)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,098评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,213评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,960评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,519评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,512评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,533评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,914评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,804评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,563评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,644评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,350评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,933评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,908评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,146评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,847评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,361评论 2 342

推荐阅读更多精彩内容