经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » 微信小程序 » 查看文章
微信小程序开发之左右分栏效果的实例代码
来源:jb51  时间:2019/5/20 10:49:03  对本文有异议

本文以一个简单的小例子,简述在微信小程序开发中左右分栏功能的实现方式,主要涉及scroll-view ,列表数据绑定,及简单样式等内容,属于初级入门内容,仅供学习分享使用。

概述

在微信小程序开发中,左右分栏(左边显示分类,右边显示明细,然后进行联动)是一种常见的布局方式,多应用于点餐,冷饮店,外卖,以及其他类似的商城。

布局分析

布局分析图示如下:

涉及知识点

•scroll-view 可滚动视图区域。使用竖向滚动时,需要给<scroll-view>一个固定高度,通过 WXSS 设置 height。组件属性的长度单位默认为px,2.4.0起支持传入单位(rpx/px)。
•scroll-y  是否允许纵向滚动,默认false。
•scroll-into-view  值应为某子元素id(id不能以数字开头)。设置哪个方向可滚动,则在哪个方向滚动到该元素(动态更新该属性的值,实现左右联动)。
•view 基础控件。
•hover-class   设置指定按下去的样式类。当 hover-class="none" 时,没有点击态效果。
•wx:for 在组件上使用 wx:for 控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。默认数组的当前项的下标变量名默认为 index,数组当前项的变量名默认为 item。
•bindtap='showItem' 绑定组件的单击事件,不加括弧。

示例效果图

示例效果图如下所示:

核心代码

WXML代码如下:

  1. <!--pages/show/show.wxml-->
  2. <view class="show-info">
  3. <scroll-view class='left' scroll-y>
  4. <view class="jy-item" wx:for="{{jytype}}" wx:key="id" hover-class="jy-item-hover" wx:for-item="item" bindtap='showItem' data-id="{{item.id}}">
  5. <image src="{{item.url}}"></image>
  6. <label>{{item.name}}</label>
  7. </view>
  8. </scroll-view>
  9. <scroll-view class='right' scroll-y scroll-into-view="{{viewId}}">
  10. <view class="jy-detail" wx:for="{{jydetail}}" wx:key="id" id= "D-{{detail.typeid}}-{{detail.id}}" wx:for-item="detail" bindtap='showDetail' data-id="{{detail.id}}">
  11. <image src="{{detail.url}}"></image>
  12. <label>{{detail.name}}</label>
  13. </view>
  14. </scroll-view>
  15. </view>

JS代码如下:

  1. showItem: function(event) {
  2. var that=this;
  3. var viewId = "D-" + event.currentTarget.dataset.id + "-" + event.currentTarget.dataset.id+"00";
  4. that.setData({
  5. viewId: viewId
  6. });
  7. console.log(viewId);
  8. },

WXSS布局如下,此处主要用到了盒子布局(display: flex;flex-direction: row;):

  1. .show-info {
  2. height: 100%;
  3. display: flex;
  4. flex-direction: row;
  5. align-items: flex-start;
  6. padding: 10rpx 0;
  7. box-sizing: border-box;
  8. }
  9.  
  10. .left {
  11. width: 30%;
  12. height: 100%;
  13. display: flex;
  14. flex-direction: column;
  15. margin:2px;
  16. }
  17. .jy-item-hover{
  18. border: none;
  19. }
  20. .right {
  21. width: 70%;
  22. height: 1200rpx;
  23. display: flex;
  24. flex-direction: column;
  25. margin: 2px;
  26. }

总结

以上所述是小编给大家介绍的微信小程序开发之左右分栏效果的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对w3xue网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号