小顺序是长在微信上的,是挪动端的界面,为了能够更轻易的运用,我们经常愿望运用九宫格界面的体式格局作为导航,那要怎样完成呢?
基于一个简朴的思索,九宫格就是三行三列,如果把行作为一个单元,再将每一行分红三列,那是不是就能够了?我们实践一下。
首先来斟酌九宫格数据的天生,每一个格子须要有一个图标、一个题目、一个便于跳转的路由,那天如今我们有九个页面,所以定义一个一维数组即可。为了更好的举行后续的设置,我们将这个数组自力到一个文件中routes.js,然后将其在index.js页面中援用,routes放到index的目录下。
var PageItems =
[
{
text: '格子1',
icon: '../../images/c1.png',
route: '../c1/c1',
},
{
text: '格子2',
icon: '../../images/c2.png',
route: '../c2/c2',
},
{
text: '格子3',
icon: '../../images/c3.png',
route: '../c3/c3',
},
{
text: '格子4',
icon: '../../images/c4.png',
route: '../c4/c4',
},
{
text: '格子5',
icon: '../../images/c5',
route: '../c5/c5',
},
{
text: '格子6',
icon: '../../images/c6.png',
route: '../c6/c6',
},
{
text: '格子7',
icon: '../../images/c7.png',
route: '../c7/c7',
},
{
text: '格子8',
icon: '../../images/c8',
route: '../c8/c8',
},
{
text: '格子9',
icon: '../../images/c9.png',
route: '../c9/c9',
}
];
module.exports = {
PageItems: PageItems
}
在index.js页面中我们援用routes.js,然后获得数据PageItems,但PageItems是一维数组,而我们前面思索是要用一行三列为一个组的,所以须要将这一维数组举行重新组合,最直接的要领就是天生一个数组,每一个数组的元素又包含了一个只要三个元素的一维数组,代码以下
//index.js
//猎取运用实例
var app = getApp()
var routes = require('routes');
Page({
data: {
userInfo: {},
cellHeight: '120px',
pageItems: []
},
//事宜处置惩罚函数
onLoad: function () {
var that = this
console.log(app);
//挪用运用实例的要领猎取全局数据
app.getUserInfo(function (userInfo) {
wx.setNavigationBarTitle({
title: '全新测试追踪体系-' + userInfo.nickName,
success: function (res) {
// success
}
})
that.setData({
userInfo: userInfo
})
var pageItems = [];
var row = [];
var len = routes.PageItems.length;//重组PageItems
len = Math.floor((len + 2) / 3) * 3;
for (var i = 0; i < len; i++) {
if ((i + 1) % 3 == 0) {
row.push(indexs.PageItems[i]);
pageItems.push(row);
row = [];
continue;
}
else {
row.push(indexs.PageItems[i]);
}
}
wx.getSystemInfo({
success: function (res) {
var windowWidth = res.windowWidth;
that.setData({
cellHeight: (windowWidth / 3) + 'px'
})
},
complete: function () {
that.setData({
pageItems: pageItems
})
}
})
})
}
})
在index.wxml中,我们来规划界面,因为每一个格子都是一样的,只是数据不一样,所以想到用模板来显现。为此,我们先做一个单元格的模板面cell.wxml.
<template name="cell">
<navigator url="{{route}}" class="pages-item" style="height:{{cellHeight}}">
<view class="{{text==null||text.length==0?'pages-icon-wrapper-no-bg':'pages-icon-wrapper'}}" >
<image src="{{icon}}" class="pages-icon"></image>
</view>
<view class="pages-text-wrapper">
<text class="pages-text">{{text}}</text>
</view>
</navigator>
</template>
这里看到两个大括号内套的是从表面传入的数据,然后在里面能够举行简朴的逻辑推断,以便于更好的显现。比方text==null的时刻,我们愿望显现的是一个空背景的格子,在有数据的时刻我们愿望显现一个含背景的格子,所以
"{{text==null||text.length==0?'pages-icon-wrapper-no-bg':'pages-icon-wrapper'}}".
别的一点,因为我们是将该界面文件作为模板的,所以必需要用template标记来包住,同时命一个名字name,如许在援用模板的地刚刚能够辨认挪用。
如今我们在index.wxml中援用这个模板
<!--index.wxml-->
<import src="cell.wxml" />
<view class="pages-container">
<scroll-view scroll-y="true" class="pages-wrapper">
<view wx:for="{{pageItems}}" wx:key="{{text}}">
<view class="pages-row">
<template is="cell" data="{{...item[0],cellHeight}}" />
<template is="cell" data="{{...item[1],cellHeight}}" />
<template is="cell" data="{{...item[2],cellHeight}}" />
</view>
</view>
</scroll-view>
</view>
模板的援用运用import来援用,在挪用的处所运用template和is,个中is指定的是cell.wxml中的name。item[0]、item[1]、item[2]是轮回传入的数据,cellHeight是在index.js的data中寄存的数据。在将数据传入到模板内部时,框架会将其展开在字段的情势,即key-value对,所以再看cell.wxml文件,就会发明内部是直接运用key来作为数据的。
将数据显现到界面以后,我们须要相称的款式来合营,index.wxss代码以下。
/**index.wxss**/
.pages-container {
height: 100%;
display: flex;
flex-direction: column;
box-sizing: border-box;
padding-top: 10rpx;
padding-bottom: 10rpx;
}
.pages-title-bg {
width: 100%;
}
.pages-wrapper {
}
.pages-row {
width: 100%;
display: flex;
flex-direction: row;
justify-content: space-around;
}
.pages-item {
position: relative;
padding: 10rpx;
width: 33%;
background-color: #fff;
border: #ddd solid 1px;
}
.pages-icon-wrapper {
display: flex;
justify-content: space-around;
align-items: center;
margin: 10rpx;
border-radius: 30%;
height: 75%;
background:#00CD0D;
}
.pages-icon-wrapper-no-bg {
display: flex;
justify-content: space-around;
align-items: center;
margin: 10rpx;
height: 75%;
}
.pages-icon {
width: 100rpx;
height: 100rpx;
}
.pages-text-wrapper {
text-align: center;
}
.pages-text {
font-weight: bolder;
}
结果以下图
我们模板中运用navigator元夙来显现格子,所以每一个格子天然就能够导航了。