本文实例讲述了微信小程序MUI侧滑导航菜单。分享给大家供大家参考,具体如下:
实现的目标MUI的off canvas效果
点击列表 —- 右侧展示页面不动,左侧导航滑动 —- 点击右侧遮罩层或者左侧选项 —- 左侧还原,右侧去掉遮罩层
实现方案2:左右分上下两层,左侧滑动,右侧不动
WXML
<view class="page"> <view class="page-top {{open "> <view class="nav-list" wx:for-items="{{nav_list}}" bindtap="open_list" data-title="{{item}}"> <text>{{item}}</text> </view> </view> <view class="page-bottom"> <image class="off-nav-list" bindtap="off_canvas" src="/UploadFiles/2021-04-02/btn.png">WXSS
page,.page { height: 100%; font-family: 'PingFang SC', 'Helvetica Neue', Helvetica, 'Droid Sans Fallback', 'Microsoft Yahei', sans-serif; } /*左侧导航 */ .page-top{ position: fixed; width: 75%; height: 100%; top: 0; left: 0; background-color: rgb(0, 68, 97); transform: rotate(0deg) scale(1) translate(-100%,0%); -webkit-transform: rotate(0deg) scale(1) translate(-100%,0%); transition: all 0.4s ease; z-index: 998; } .page-top-show{ transform: rotate(0deg) scale(1) translate(0%,0%); -webkit-transform: rotate(0deg) scale(1) translate(0%,0%); } .nav-list{ padding: 30rpx 0 30rpx 40rpx; color:#fff; } /*右侧展示 */ .page-bottom{ height: 100%; background-color: rgb(57, 125, 230); position: relative; } .off-nav-list{ position: fixed; width: 60rpx; height: 50rpx; top: 20rpx; left:20rpx; } .page-bottom-content{ padding:100rpx 20rpx 30rpx; color: #fff; } .page-mask{ width: 100%; height: 100%; background-color:rgba(0,0,0,0.5); position: absolute; top: 0; left: 0; z-index: 10; } .page-mask-hide{ display: none; }JS
var app = getApp(); var data = require('../../utils/data.js'); Page({ /** * 页面的初始数据 */ data: { text: 'ES6学习之路', nav_list: ['ES6学习之路', 'CSS特效', 'VUE实战','微信小程序'], open: false }, //列表的操作函数 open_list: function(opts){ this.setData({ text: opts.currentTarget.dataset.title,open: false}); }, //左侧导航的开关函数 off_canvas: function(){ this.data.open "font-size: medium">总结:1. 代码简化:off_canvas函数简化代码,采用三目表达式,简单切清晰;
2. 渲染:注意对data对象中属性进行赋值时,要采用
this.setData()
方法,否则属性改变不会重新渲染(eg:this.data.text = opts.currentTarget.dataset.title;
)这样text的值改变,页面不会重新渲染text;3. 代码简化:
this.data.open ? this.setData({open: false}) :this.setData({open: true});
简化为this.setData({ open: this.data.open ? false : true});
希望本文所述对大家微信小程序开发有所帮助。
风云阁资源网 Design By www.bgabc.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
风云阁资源网 Design By www.bgabc.com
暂无评论...
更新日志
2024年11月15日
2024年11月15日
- 黄妃.2020-色違【米乐士娱乐】【FLAC分轨】
- LouisHayes-ArtformRevisited(2024)[24Bit-96kHz]FLAC
- 永恒英文金曲精选5《TheBestOfEverlastingFavouritesVol.5》[WAV+CUE]
- 黑鸭子2005-紫丁香[首版][WAV+CUE]
- 林忆莲《爱上一个不回家的人》XRCD版[低速原抓WAV+CUE][999M]
- 经典《历届奥斯卡金曲回顾》[正版原抓WAV+CUE] [1G]
- 群星《试音草原·女声篇》经典蒙古民歌[WAV+CUE][1G]
- 炉石传说月末上分卡组推荐 国服月末最快上分卡组推荐
- 炉石传说月底最强卡组有哪些 2024国服月底最强卡组推荐
- 炉石传说月初最强卡组有哪些 2024月初最强上分卡组推荐
- 狼人杀亮相原生鸿蒙之夜 假面科技强势登陆华为生态
- 12小时光线挑战!AI画质专家才是大平层首选
- 2024游戏IP报告:1~9月规模1960亿 68%用户愿为之付费
- 群星.2024-今夜一起为爱鼓掌电视剧原声带【相信音乐】【FLAC分轨】
- BIGFOUR.2013-大家利事【寰亚】【WAV+CUE】