`
郭丶小川
  • 浏览: 33677 次
社区版块
存档分类
最新评论

微信小程序编写tabBar模板,map组件markers属性动态初始化

阅读更多
一:编写tabBar模板

众所周知,微信小程序的tabBar都是新开页面的,而微信文档上又表明了最多只能打开5层页面。这样就很容易导致出问题啦,假如我的tabBar有5个呢?下面是微信原话:

一个应用同时只能打开5个页面,当已经打开了5个页面之后,wx.navigateTo不能正常打开新页面。请避免多层级的交互方式,或者使用wx.redirectTo

因此这几天想着根据微信tabBar数组来自定义模板供页面调用。不过我在list里面每个对象都增加了一个selectedColor和active属性,方便对每个tabBar当前页做样式,如果不传直接使用设置的selectedColor。因此这串数据只能设定在各个页面下,不能设定在公用的app.js配置文件下,稍微有点代码冗余,下次研究下怎么直接配置到app.js完善下。

只要新建一个tarBar.wxml模板页,然后引用模板的页面传入数据即可,代码如下:
<template name="tabBar"> 
  <view class="flex-h flex-hsb tab-bar" style="color: {{tabBar.color}}; background: {{tarBar.backgroundColor}}; {{tabBar.position=='top'? 'top: 0' : 'bottom: 0'}}; {{tabBar.borderStyle? (tabBar.position=='top'? 'border-bottom: solid 1px '+tabBar.borderStyle + ';' : 'border-top: solid 1px '+tabBar.borderStyle + ';') : ''}}"> 
  <block wx:for="{{tabBar.list}}" wx:key="pagePath"> 
    <navigator url="{{item.pagePath}}" open-type="redirect" class="menu-item" style="{{item.active? 'color: '+(item.selectedColor? item.selectedColor : tabBar.selectedColor) : ''}}"> 
      <image src="{{item.selectedIconPath}}" wx:if="{{item.active}}"></image> 
      <image src="{{item.iconPath}}" wx:if="{{!item.active}}"></image> 
      <text>{{item.text}}</text> 
    </navigator> 
    </block> 
  </view> 
</template> 
复制代码
接下来进行测试,首先是index.js的配置对象:
//配置tabBar 
    tabBar: { 
      "color": "#9E9E9E", 
      "selectedColor": "#f00", 
      "backgroundColor": "#fff", 
      "borderStyle": "#ccc", 
      "list": [ 
        { 
          "pagePath": "/pages/index/index", 
          "text": "主页", 
          "iconPath": "../../img/tabBar_home.png", 
          "selectedIconPath": "../../img/tabBar_home_cur.png", 
          //"selectedColor": "#4EDF80", 
          active: true 
        }, 
        { 
          "pagePath": "/pages/village/city/city", 
          "text": "目的地", 
          "iconPath": "../../img/tabBar_village.png", 
          "selectedIconPath": "../../img/tabBar_village_cur.png", 
          "selectedColor": "#4EDF80", 
          active: false 
        }, 
        { 
          "pagePath": "/pages/mine/mine", 
          "text": "我的", 
          "iconPath": "../../img/tabBar_mine.png", 
          "selectedIconPath": "../../img/tabBar_mine_cur.png", 
          "selectedColor": "#4EDF80", 
          active: false 
        } 
      ], 
      "position": "bottom" 
    }
复制代码
index.wxml引入模板:
<import src="../../template/tabBar.wxml" /> 
<template is="tabBar" data="{{tabBar: tabBar}}" /> 
复制代码
接下来是mine.js文件引入配置对象:
//配置tabBar 
    tabBar: { 
      "color": "#9E9E9E", 
      "selectedColor": "#f00", 
      "backgroundColor": "#fff", 
      "borderStyle": "#ccc", 
      "list": [ 
        { 
          "pagePath": "/pages/index/index", 
          "text": "主页", 
          "iconPath": "../../img/tabBar_home.png", 
          "selectedIconPath": "../../img/tabBar_home_cur.png", 
          //"selectedColor": "#4EDF80", 
          active: false 
        }, 
        { 
          "pagePath": "/pages/village/city/city", 
          "text": "目的地", 
          "iconPath": "../../../img/tabBar_village.png", 
          "selectedIconPath": "../../../img/tabBar_village_cur.png", 
          "selectedColor": "#4EDF80", 
          active: false 
        }, 
        { 
          "pagePath": "/pages/mine/mine", 
          "text": "我的", 
          "iconPath": "../../img/tabBar_mine.png", 
          "selectedIconPath": "../../img/tabBar_mine_cur.png", 
          "selectedColor": "#4EDF80", 
          active: true 
        } 
      ], 
      "position": "bottom" 
    } 
复制代码
mine.wxml引入模板:
<import src="../../template/tabBar.wxml" /> 
<template is="tabBar" data="{{tabBar: tabBar}}" /> 
复制代码
最后演示如下:
1.gif
方案二

我把配置数据统一放在app.js文件,通过点击跳转页面后在把数据添加到当前页面实例上,具体做法如下:

    1、app.js文件配置:
//app.js 
var net = require('common/net'); 
var a_l, a_d = {}, a_cbSucc, a_cbSuccFail, a_cbFail, a_cbCom, a_h, a_m; 
App({ 
  onLaunch: function () { 
    var that = this; 
  }, 
  //修改tabBar的active值 
  editTabBar: function () { 
    var _curPageArr = getCurrentPages(); 
    var _curPage = _curPageArr[_curPageArr.length - 1];<span style="font-family: Arial, Helvetica, sans-serif;">//相当于Page({})里面的this对象</span> 
    var _pagePath=_curPage.__route__; 
    if(_pagePath.indexOf('/') != 0){ 
      _pagePath='/'+_pagePath; 
    } 
    var tabBar=this.globalData.tabBar; 
    for(var i=0; i<tabBar.list.length; i++){ 
      tabBar.list.active=false; 
      if(tabBar.list.pagePath==_pagePath){ 
        tabBar.list.active=true;//根据页面地址设置当前页面状态 
      } 
    } 
    _curPage.setData({ 
      tabBar: tabBar 
    }); 
  }, 
  globalData: { 
    userInfo: null, 
    //配置tabBar 
    tabBar: { 
      "color": "#9E9E9E", 
      "selectedColor": "#f00", 
      "backgroundColor": "#fff", 
      "borderStyle": "#ccc", 
      "list": [ 
        { 
          "pagePath": "/pages/index/index", 
          "text": "主页", 
          "iconPath": "/pages/templateImg/tabBar_home.png", 
          "selectedIconPath": "/pages/templateImg/tabBar_home_cur.png", 
          "selectedColor": "#4EDF80", 
          active: false 
        }, 
        { 
          "pagePath": "/pages/village/city/city", 
          "text": "目的地", 
          "iconPath": "/pages/templateImg/tabBar_village.png", 
          "selectedIconPath": "/pages/templateImg/tabBar_village_cur.png", 
          "selectedColor": "#4EDF80", 
          active: false 
        }, 
        { 
          "pagePath": "/pages/mine/mine", 
          "text": "我的", 
          "iconPath": "/pages/templateImg/tabBar_mine.png", 
          "selectedIconPath": "/pages/templateImg/tabBar_mine_cur.png", 
          "selectedColor": "#4EDF80", 
          active: false 
        } 
      ], 
      "position": "bottom" 
    } 
  } 
}) 
复制代码
2、index.js+mine.js+city.js页面使用:
var App=getApp(); 
Page({ 
  data:{ 
    detail: {}, 
  }, 
  onLoad:function(options){ 
    App.editTabBar();//添加tabBar数据 
    var that=this; 
  } 
}) 
复制代码
最终演示和上图一致!


二:map组件markers属性动态初始化

今天在写小程序详情页时候遇到一个问题,map组件的markers属性是通过异步请求到数据后设置的,结果就导致了微信底层渲染出错。但是如果我先在data初始化markers变量,每次小程序都不能正常渲染都是初始化的北京的数据。然后写了如下测试:

test.js:
Page({ 
  data:{ 
    map:{ 
      lat: 0, 
      lng: 0, 
      markers: [], 
      hasMarkers: false//解决方案 
    } 
  }, 
  onLoad: function(options){ 
    var that=this; 
    wx.getLocation({ 
      type: 'wgs84', // 默认为 wgs84 返回 gps 坐标,gcj02 返回可用于 wx.openLocation 的坐标 
      success: function (res) { 
        // success 
        wx.request({ 
          url: 'https://xxx.com/detail.htm?vid=3&latlng=' + res.latitude + ',' + res.longitude, 
          data: {}, 
          method: 'GET', // OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT 
          // header: {}, // 设置请求的 header 
          success: function (res) { 
            // success 
            that.setData({ 
              'map.lat': res.data.data.lat, 
              'map.lng': res.data.data.lng, 
              'map.markers': [{ 
                latitude: res.data.data.lat, 
                longitude: res.data.data.lng, 
                name: res.data.data.title, 
                desc: res.data.data.address 
              }], 
              'map.hasMarkers': true//解决方案 
            }); 
            console.log(that.data.map.markers); 
          } 
        }) 
      } 
    }) 
  } 
}); 
复制代码
test.wxml:
<view style="height: 100rpx;"> 
{{map.lat}}--{{map.lng}}--{{map.markers[0].name}}--{{map.markers[0].desc}} 
</view> 
<map latitude="{{map.lat}}" longitude="{{map.lng}}" markers="{{map.markers}}"></map> 
复制代码
测试一:data里面没有初始化map变量
2.jpg
测试二:初始化map变量,并在wxml把map数据都打印出来
3.jpg
为什么会这样呢??各种测试,最后发现只要不是经过远程请求在来设置map值就不会出问题。

后来经大神网友提点,由于异步设置值的过程,组件已经渲染。但是map变量没有预定义是undefined状态,map初始化拿不到数据直接报错了,而异步过来又变成动态更新导致了wxml需要重新渲染map组件的情况导致的。因为官方文档有提到:

地图组件的经纬度必填, 如果不填经纬度则默认值是北京的经纬度。 标记点markers只能在初始化的时候设置,不支持动态更新。

只能初始化一次,因此导致每次都是显示的初始化信息。

然后,网友给出的解决方案完美解决了这个问题:

wx:if会渲染一下组件,那我们按照这个思路给他加个if就行了
<map markers="{{markers}}" style="width: 375px; height: 200px;" wx:if="{{map}}"></map>
复制代码
默认map是false,就是加载时不渲染map组件,等ajax回来后把map设置为true,这样就动态渲染成你要的地址了

原文链接:http://bbs.jointforce.com/topic/25439
分享到:
评论

相关推荐

    微信小程序 自定义tabbar (源码)

    微信小程序 自定义tabbar (源码)微信小程序 自定义tabbar (源码)微信小程序 自定义tabbar (源码)微信小程序 自定义tabbar (源码)微信小程序 自定义tabbar (源码)微信小程序 自定义tabbar (源码)微信小程序 自定义...

    微信小程序底部tab-bar组件,高度还原微信原生tabBar功能及样式,且兼容iPhone异形全面屏

    微信小程序底部的`tab-bar`组件是开发微信小程序时不可或缺的一部分,它提供了与微信原生应用相似的底部导航栏功能,使得用户可以在多个主要页面间快速切换。此组件的设计目标是确保高度还原微信官方的`tabBar`样式...

    优雅实现微信小程序动态tabBar,根据不同用户角色显示不同底部导航-更新版(支持自由组合总数超过5个tabBar菜单)

    2、使用自定义底部导航custom-tab-bar优雅实现微信小程序动态tabBar。 3、实现自由组合tabBar菜单项目,支持自由组合总数超过5个tabBar菜单。 4、本示例是7个底部导航,分2种权限,权限1显示1,2,3;权限2显示4,5...

    微信小程序——自定义tabbar(截图+源码).zip

    微信小程序——自定义tabbar(截图+源码).zip 微信小程序——自定义tabbar(截图+源码).zip 微信小程序——自定义tabbar(截图+源码).zip 微信小程序——自定义tabbar(截图+源码).zip 微信小程序——自定义...

    微信小程序tabbar图标素材

    在微信小程序中,TabBar 是一个至关重要的组件,它位于小程序页面底部,通常包含固定的一组功能入口,如首页、分类、购物车、个人中心等,为用户提供便捷的操作导航。 TabBar 图标是用户界面设计中的关键元素,它们...

    微信小程序底部tabbar图片

    此外,我们还可以通过编写自定义组件或使用微信小程序的API动态改变tabBar的状态和样式,以实现更丰富的交互效果。例如,在用户完成特定操作后,可以短暂高亮某个tab,或者在特定条件下隐藏某个tab。 最后,对于...

    微信小程序自定义tabBar,中间圆形凸起

    原生的微信小程序`tabBar`虽然提供了基本的样式和功能,但往往无法满足开发者对个性化设计的需求。本文将深入探讨如何实现一个中间圆形凸起的自定义`tabBar`,并介绍如何使其支持`darkMode`(深色主题)以及iPhoneX...

    uniapp 微信小程序tabbar凸起的显示

    在开发微信小程序时,UI设计和用户体验是至关重要的部分,特别是在构建导航栏(tabbar)时。`uniapp`是一个跨平台的开发框架,它允许开发者使用一套代码库来构建多端应用,包括微信小程序。在`uniapp`中处理微信小...

    优雅实现微信小程序动态tabBar,根据不同用户角色显示不同底部导航

    内容概要: ...2、使用自定义底部导航 custom-tab-bar优雅实现微信小程序动态tabBar。 适合人群: 1、具备一定编程基础,熟悉小程序开发者 能学到什么: 1、使用自定义组件,完全接管 tabBar 的渲染。

    微信小程序官方动态自定义底部tabBar的例子

    微信小程序官方动态自定义底部tabBar是一种实现动态切换底部导航菜单的方式,它可以根据用户的实际需求,实现更加灵活和个性化的底部tabBar展示效果。本文将详细介绍微信小程序官方提供的动态自定义底部tabBar的实现...

    微信小程序-微信小程序自定义tabbar,包含可左右滚动

    在这个特定的项目“wx-mina-custom-tabbar”中,开发者旨在创建一个自定义的TabBar组件,该组件具备左右滚动的功能,以满足用户在微信小程序中的个性化需求。 TabBar在移动应用设计中是非常常见的一种导航模式,它...

    微信小程序自定义tabbar源码

    微信小程序官方提供了默认的tabbar样式,但有时这并不足以满足所有设计需求,因此,自定义tabbar源码的编写就显得尤为重要。 自定义tabbar涉及的主要知识点包括: 1. **小程序配置**:首先,你需要在`app.json`...

    微信小程序源码(含截图)自定义tabbar

    微信小程序源码(含截图)自定义tabbar微信小程序源码(含截图)自定义tabbar微信小程序源码(含截图)自定义tabbar微信小程序源码(含截图)自定义tabbar微信小程序源码(含截图)自定义tabbar微信小程序源码(含...

    微信小程序自定义tabbar中间突起样式

    在微信小程序中,`tabbar` 是一个基础且重要的组件,它通常位于页面底部,用于展示应用的主要功能模块,方便用户快速切换。本文将深入探讨如何在微信小程序中自定义`tabbar`,特别是实现中间突起的样式。 1. **...

    微信小程序源码 自定义tabbar(学习版)

    微信小程序源码 自定义tabbar(学习版)微信小程序源码 自定义tabbar(学习版)微信小程序源码 自定义tabbar(学习版)微信小程序源码 自定义tabbar(学习版)微信小程序源码 自定义tabbar(学习版)微信小程序源码 自定义...

    小程序tabbar素材

    在微信小程序开发中,TabBar 是一个至关重要的组件,它位于小程序页面的底部,用于展示主要功能模块的快捷入口,通常包含2-5个图标和文字。本资源包"小程序tabbar素材"提供了专为微信小程序设计的TabBar图形元素,以...

    微信小程序demo:点击tabbar变换图标

    在这个“微信小程序demo:点击tabbar变换图标”的项目中,我们将深入探讨如何在微信小程序中实现TabBar(底部导航栏)的图标动态切换功能。 首先,TabBar是微信小程序中常用的一种界面元素,它位于应用的底部,通常...

    小程序自定义tabbar

    在微信小程序中,开发者有时需要根据自己的应用设计和交互需求,对系统默认的tabbar进行自定义,以提供更个性化的用户体验。标题“小程序自定义tabbar”所指的就是这个过程,即通过编写HTML和JavaScript代码,来创建...

    微信小程序跳转tabBar携带参数怎么办?

    微信小程序的导航跳转分为navigateTo(保留当前页,跳转到应用内的其他页面,跳转非tabBar页面,可带参数,但是这里有个小坑,后面说),  navigateBack(关闭当前页面,返回上一页面或多级页面),  redirectTo...

Global site tag (gtag.js) - Google Analytics