微信小程序开发之左右分栏效果的实例代码


Posted in Javascript onMay 20, 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第三课 修改元素属性及内容的代码
Mar 14 Javascript
基于jquery的商品展示放大镜
Aug 07 Javascript
jquery append()方法与html()方法的区别及使用介绍
Aug 01 Javascript
jQuery中click事件用法实例
Dec 26 Javascript
分享2个jQuery插件--jquery.fileupload与artdialog
Dec 26 Javascript
JS实现当前页居中分页效果的方法
Jun 18 Javascript
浅谈webpack组织模块的原理
Mar 10 Javascript
webpack4 SCSS提取和懒加载的示例
Sep 03 Javascript
ndm:NPM的桌面GUI应用程序
Oct 15 Javascript
浅析微信小程序modal弹窗关闭默认会执行cancel问题
Oct 14 Javascript
vscode 插件开发 + vue的操作方法
Jun 05 Javascript
JS实现数据动态渲染的竖向步骤条
Jun 24 Javascript
微信小程序rich-text富文本用法实例分析
May 20 #Javascript
bootstrap中的导航条实例代码详解
May 20 #Javascript
详解小程序云开发数据库
May 20 #Javascript
VUE脚手架具体使用方法
May 20 #Javascript
Vue CLI2升级至Vue CLI3的方法步骤
May 20 #Javascript
解决Vue+Electron下Vuex的Dispatch没有效果问题
May 20 #Javascript
微信小程序上传文件到阿里OSS教程
May 20 #Javascript
You might like
php与paypal整合方法
2010/11/28 PHP
php下尝试使用GraphicsMagick的缩略图功能
2011/01/01 PHP
php图片加中文水印实现代码分享
2012/10/31 PHP
php实现基于openssl的加密解密方法
2016/09/30 PHP
理解Javascript_08_函数对象
2010/10/15 Javascript
node.js正则表达式获取网页中所有链接的代码实例
2014/06/03 Javascript
jQuery实现可展开合拢的手风琴面板菜单
2015/09/15 Javascript
Bootstrap与KnockoutJs相结合实现分页效果实例详解
2016/05/03 Javascript
jquery ajax局部加载方法详解(实现代码)
2016/05/12 Javascript
原生js中ajax访问的实例详解
2017/09/19 Javascript
vue-cli的eslint相关用法
2017/09/29 Javascript
laydate时间日历插件使用方法详解
2018/11/14 Javascript
使用koa2创建web项目的方法步骤
2019/03/12 Javascript
js实现for循环跳过undefined值示例
2019/07/02 Javascript
jquery多级树形下拉菜单的实例代码
2019/07/09 jQuery
详解vue-video-player使用心得(兼容m3u8)
2019/08/23 Javascript
Vue.js实现大屏数字滚动翻转效果
2019/11/29 Javascript
JS实现省市县三级下拉联动
2020/04/10 Javascript
Python中使用select模块实现非阻塞的IO
2015/02/03 Python
深入解析Python中的lambda表达式的用法
2015/08/28 Python
python实现黑客字幕雨效果
2018/06/21 Python
把csv文件转化为数组及数组的切片方法
2018/07/04 Python
python sorted函数原理解析及练习
2020/02/10 Python
如何使用PyCharm将代码上传到GitHub上(图文详解)
2020/04/27 Python
CSS3实现时间轴效果
2016/07/11 HTML / CSS
HTML5单页面手势滑屏切换原理分析
2017/07/10 HTML / CSS
Aveda美国官网:天然护发产品、洗发水、护发素和沙龙
2016/12/09 全球购物
印度尼西亚值得信赖的第一家网店:Bhinneka
2018/07/16 全球购物
我的未来不是梦演讲稿
2014/09/02 职场文书
毕业证代领委托书
2014/09/26 职场文书
社区班子个人对照检查材料思想汇报
2014/10/07 职场文书
党员个人整改方案及措施
2014/10/25 职场文书
2014年度个人工作总结
2014/11/07 职场文书
2015年业务员工作总结范文
2015/04/07 职场文书
关于Javascript闭包与应用的详解
2021/04/22 Javascript
cypress测试本地web应用
2022/06/01 Javascript