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


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 相关文章推荐
利用JQuery的load函数动态加载其它页面的内容的实现代码
Dec 14 Javascript
原生javascript图片自动或手动切换示例附演示源码
Sep 04 Javascript
js获取url中指定参数值的示例代码
Dec 14 Javascript
如何让你的Lightbox支持滚轮缩放及Base64图片
Dec 04 Javascript
js实现浏览器窗口大小被改变时触发事件的方法
Feb 02 Javascript
JS实现可直接显示网页代码运行效果的HTML代码预览功能实例
Aug 06 Javascript
JavaScript 基础函数_深入剖析变量和作用域
May 18 Javascript
jquery横向纵向鼠标滚轮全屏切换
Feb 27 Javascript
微信小程序图片横向左右滑动案例
May 19 Javascript
彻底搞懂JavaScript中的apply和call方法(必看)
Sep 18 Javascript
JavaScript 扩展运算符用法实例小结【基于ES6】
Jun 17 Javascript
全网小程序接口请求封装实例代码
Nov 06 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实现jQuery扩展函数
2009/10/30 PHP
PHP多线程之内部多线程实例分析
2015/03/09 PHP
ThinkPHP框架搭建及常见问题(XAMPP安装失败、Apache/MySQL启动失败)
2016/04/15 PHP
PHP Laravel 上传图片、文件等类封装
2017/08/16 PHP
PHP+jQuery实现即点即改功能示例
2019/02/21 PHP
用JavaScript脚本实现Web页面信息交互
2006/10/11 Javascript
Javascript前端UI框架Kit使用指南之Kitjs简介
2014/11/28 Javascript
javascript截取字符串小结
2015/04/28 Javascript
jquery validate.js表单验证入门实例(附源码)
2015/11/10 Javascript
jQuery EasyUI 菜单与按钮之创建简单的菜单和链接按钮
2015/11/18 Javascript
js立即执行函数: (function ( ){})( ) 与 (function ( ){}( )) 有什么区别?
2015/11/18 Javascript
zTree插件下拉树使用入门教程
2016/04/11 Javascript
JQuery核心函数是什么及使用方法介绍
2016/05/03 Javascript
Bootstrap模仿起筷首页效果
2016/05/09 Javascript
学习掌握JavaScript中this的使用技巧
2016/08/29 Javascript
JavaScript计算值然后把值嵌入到html中的实现方法
2016/10/29 Javascript
js,jq,css多方面实现简易下拉菜单功能
2017/05/13 Javascript
微信小程序按钮去除边框线分享页面功能
2018/08/27 Javascript
Intellij IDEA搭建vue-cli项目的方法步骤
2018/10/20 Javascript
详解微信小程序(Taro)手动埋点和自动埋点的实现
2021/03/02 Javascript
Python使用ftplib实现简易FTP客户端的方法
2015/06/03 Python
Django组件之cookie与session的使用方法
2019/01/10 Python
Python partial函数原理及用法解析
2019/12/11 Python
python dumps和loads区别详解
2020/02/04 Python
python标准库sys和OS的函数使用方法与实例详解
2020/02/12 Python
python openCV实现摄像头获取人脸图片
2020/08/20 Python
详解python tkinter包获取本地绝对路径(以获取图片并展示)
2020/09/04 Python
Free People中国官网:波西米亚风格女装服饰
2016/08/30 全球购物
怎样客观的做好自我评价
2013/12/28 职场文书
优秀社区干部事迹材料
2014/02/03 职场文书
学生生病请假条范文
2014/02/16 职场文书
教师演讲稿开场白
2014/08/25 职场文书
介绍信范文
2015/01/31 职场文书
门球健将观后感
2015/06/16 职场文书
2015暑假社会调查报告
2015/07/13 职场文书
同学聚会开幕词
2019/04/02 职场文书