微信小程序之左右布局的实现代码


Posted in Javascript onDecember 13, 2019

本文以一个简单的小例子,简述在微信小程序开发中左右布局功能的实现方式,主要涉及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代码如下:

<!--pages/show/show.wxml-->
<view class="show-info">
 <scroll-view class='left' scroll-y>
  <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}}">
   <image src="{{item.url}}"></image>
   <label>{{item.name}}</label>
  </view>
 </scroll-view>
 <scroll-view class='right' scroll-y scroll-into-view="{{viewId}}">
  <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}}">
   <image src="{{detail.url}}"></image>
   <label>{{detail.name}}</label>
  </view>
 </scroll-view>
</view>

JS代码如下:

showItem: function(event) {
  var that=this;
  var viewId = "D-" + event.currentTarget.dataset.id + "-" + event.currentTarget.dataset.id+"00";
  that.setData({
   viewId: viewId
  });
  console.log(viewId);
 },

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

.show-info {
 height: 100%;
 display: flex;
 flex-direction: row;
 align-items: flex-start;
 padding: 10rpx 0;
 box-sizing: border-box;
}

.left {
 width: 30%;
 height: 100%;
 display: flex;
 flex-direction: column;
 margin:2px;
}

.jy-item-hover{
 border: none;
}

.right {
 width: 70%;
 height: 1200rpx;
 display: flex;
 flex-direction: column;
 margin: 2px;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
一些有关检查数据的JS代码
Sep 07 Javascript
pjblog修改技巧汇总
Mar 12 Javascript
input、button的不同type值在ajax提交表单时导致的陷阱
Feb 24 Javascript
前端开发部分总结[兼容性、DOM操作、跨域等](持续更新)
Mar 04 Javascript
jQuery判断div随滚动条滚动到一定位置后停止
Apr 02 Javascript
Ajax+FormData+javascript实现无刷新表单信息提交
Oct 24 Javascript
详解Vue中添加过渡效果
Mar 20 Javascript
ES6中Proxy与Reflect实现重载(overload)的方法
Mar 30 Javascript
基于DOM节点删除之empty和remove的区别(详解)
Sep 11 Javascript
vue引入jq插件的实例讲解
Sep 12 Javascript
Node.js系列之发起get/post请求(2)
Aug 30 Javascript
vue 获取url里参数的两种方法小结
Nov 12 Javascript
vue实现输入一位数字转汉字功能
Dec 13 #Javascript
小程序登录之支付宝授权的实现示例
Dec 13 #Javascript
小程序使用wxs解决wxml保留2位小数问题
Dec 13 #Javascript
微信小程序点击保存图片到本机功能
Dec 13 #Javascript
微信小程序实现轨迹回放的示例代码
Dec 13 #Javascript
微信小程序 SOTER 生物认证DEMO 指纹识别功能
Dec 13 #Javascript
vue中使用elementUI组件手动上传图片功能
Dec 13 #Javascript
You might like
php字符串截取函数用法分析
2014/11/25 PHP
带你了解PHP7 性能翻倍的关键
2015/11/19 PHP
CodeIgniter钩子用法实例详解
2016/01/20 PHP
Laravel中如何轻松容易的输出完整的SQL语句
2020/07/26 PHP
JavaScript 弹出窗体点击按钮返回选择数据的实现
2010/04/01 Javascript
jQuery新闻滚动插件 jquery.roller.js
2011/06/27 Javascript
node.js中的fs.fchmod方法使用说明
2014/12/16 Javascript
JavaScript计算器网页版实现代码分享
2016/07/15 Javascript
Bootstrap 3.x打印预览背景色与文字显示异常的解决
2016/11/06 Javascript
canvas时钟效果
2017/02/16 Javascript
jQuery中的deferred对象和extend方法详解
2017/05/08 jQuery
js实现数组和对象的深浅拷贝
2017/09/30 Javascript
vue+elementUI组件table实现前端分页功能
2020/11/15 Javascript
详解node和ES6的模块导出与导入
2020/02/19 Javascript
记一次react前端项目打包优化的方法
2020/03/30 Javascript
JavaScript布尔运算符原理使用解析
2020/05/06 Javascript
学习python的几条建议分享
2013/02/10 Python
python中urllib模块用法实例详解
2014/11/19 Python
django实现同一个ip十分钟内只能注册一次的实例
2017/11/03 Python
python内置函数:lambda、map、filter简单介绍
2017/11/16 Python
浅谈Python中的作用域规则和闭包
2018/03/20 Python
详解Python中的动态属性和特性
2018/04/07 Python
详解Python列表赋值复制深拷贝及5种浅拷贝
2019/05/15 Python
Python3日期与时间戳转换的几种方法详解
2019/06/04 Python
python上传时包含boundary时的解决方法
2020/04/08 Python
pyspark对Mysql数据库进行读写的实现
2020/12/30 Python
详解CSS3中常用的样式【基本文本和字体样式】
2020/10/20 HTML / CSS
送货司机岗位职责
2013/12/11 职场文书
庆元旦广播稿
2014/02/10 职场文书
2014大学生全国两会学习心得体会
2014/03/13 职场文书
海飞丝广告词
2014/03/20 职场文书
党员查摆剖析材料
2014/10/10 职场文书
先进员工事迹材料
2014/12/20 职场文书
可可西里观后感
2015/06/08 职场文书
2016年元旦主持词
2015/07/06 职场文书
公开致歉信
2019/06/24 职场文书