小程序最顶部的导航栏如何实现

小程序最顶部的导航栏如何实现,第1张

<view class="swiper-tab">    

    <view class="swiper-tab-list {{currentTab==0 ? 'on' : ''}}" data-current="0" bindtap="swichNav">11</view>    

    <view class="swiper-tab-list {{currentTab==1 ? 'on' : ''}}" data-current="1" bindtap="swichNav">22</view>    

    <view class="swiper-tab-list {{currentTab==2 ? 'on' : ''}}" data-current="2" bindtap="swichNav">33</view>  

    <view class="swiper-tab-list {{currentTab==3 ? '正早on' : ''}}" data-current="3" bindtap="swichNav">44</view>  

    <view class="swiper-tab-list {{currentTab==4 ? 'on' : ''}}" data-current="4" bindtap="swichNav">55</view>         

</view>    

    

<swiper current="{{currentTab}}" class="swiper-box" duration="300" style="height:{{winHeight - 31}}px" bindchange="bindChange">    

    <!-- 我是哈哈 -->    

    <swiper-item>    

      <view>我是哈哈</view>    

    </swiper-item>    

    <!-- 我是呵呵 -->    

    <swiper-item>    

      <view>我是呵呵</view>    

    </swiper-item>    

    <!-- 我是嘿嘿 -->    

    <swiper-item>    

      <view>我是嘿嘿</view>    

    </swiper-item>    

    <swiper-item>    

      <view>亏清御我是嘿嘿</view>    

    </swiper-item>    

    <swiper-item>    

      <view>我是嘿嘿</view>    

    </swiper-item>    

</swiper> .swiper-tab{    

    width: 100%    

    border-bottom: 2rpx solid #777777    

    text-align: center    

    line-height: 80rpx  

    }    

.swiper-tab-list{  font-size: 30rpx    

    display: inline-block    

    width: 20%   销岩 

    color: #777777    

}    

.on{ color: #da7c0c    

    border-bottom: 5rpx solid #da7c0c}    

.swiper-box{ display: block height: 100% width: 100% overflow: hidden }    

.swiper-box view{    

    text-align: center    

} var app = getApp()    

Page( {    

  data: {    

    /**  

        * 页面配置  

        */    

    winWidth: 0,    

    winHeight: 0,    

    // tab切换    

    currentTab: 0,    

  },    

  onLoad: function() {    

    var that = this    

    

    /**  

     * 获取系统信息  

     */    

    wx.getSystemInfo( {    

    

      success: function( res ) {    

        that.setData( {    

          winWidth: res.windowWidth,    

          winHeight: res.windowHeight    

        })    

      }    

    

    })    

  },    

  /**  

     * 滑动切换tab  

     */    

  bindChange: function( e ) {    

    

    var that = this    

    that.setData( { currentTab: e.detail.current })    

    

  },    

  /**  

   * 点击tab切换  

   */    

  swichNav: function( e ) {    

    

    var that = this    

    

    if( this.data.currentTab === e.target.dataset.current ) {    

      return false    

    } else {    

      that.setData( {    

        currentTab: e.target.dataset.current    

      })    

    }     

  },  

 /** 

  * 点击分享 

  */  

  onShareAppMessage: function () {  

    return {  

      title: '装逼小程序',  

      path: '/page/user?id=123'  

    }  

  }  

})

与iOS开发很相似,小程序的导航栏也可以全局设置一下,在公共文件app.json中设置了导航栏相关样式如下:

这个地方是全局设置,如果想要在不同的页面设置各自的标题属性芹数烂,只需要在该子级文件中设置

子页面想调用共公js的方法,需先在子页面js中先实例化app:具体过程如下

在需要调用的子页面中,

如果是嵌套循环,很容易出现多个list和index,例如表视图一样,所以在小程序中可以重命名 list 和index 方法为:wx:for-index='重命名' wx:for-list="重命名"

在APP开发中,UI复用是一个很好的手段,在小程序上就是模板template。

在逛小程序联盟的时候发现了一个大湿总结的比我好,搬过来一下。

微信小程序中,如果几个页面中需要引用同一个header/footer,当定义了公共模板时,有两种引用方法如下:

方法一:在公共模板中定义template元素,利用 方法 ,这种方式只会显示公共模板的template里面的内容,之外的内容不会显示

** 方法二:**

总结:import方式和imclude方式的不同在于前者仅引用公共模板中的template里面的内容后者仅引用template以外的内容,显而易见,include方式更简单一些,在wxml中只需要一句话即可。

rpx单位是微信小程序中css的尺寸单位,rpx可以根据屏幕宽度进行自适应。规定屏幕宽为750rpx。如在 iPhone6 上,屏幕宽度为375px,共有750个物理像素,则750rpx = 375px = 750物理像素,1rpx = 0.5px。

具体的 这里有一片文章介绍的很详细 , 还有这个

小程序的事件主要有:

小程序中的wxml中绑定事件有两种:以touchtab为例 ,在wxml中必须有bind/catch不然无法实现上述事件

bindtouchtab和catchtouchtab bind的不会阻止事件冒泡(元素最里层到最外层函数执行),catch会阻止冒泡,只是冒泡到当前层结束

如果想在元素执行某事件时把元素的某个属性传到后台 可在元素中加入data-属性嫌漏名称=“xxx”,在事件函数中 function(event){}的event中的currentTarget里面的data-set里面可查看接收在元素中绑定的的id或者其他属性clientX/Y 查看滑动手指距离屏幕左侧的位置,查看滑动位置也可以通过touchstart和和touchend的clientx/y获取

看到几个别人写的,瞬间石化,果断收藏。

在小程序中,定义了一项工具文件utils,此文件的js旨在本文件之内有效,当其他子页面想调用其中的js方法或者变量时,需要两步骤:

1:在utils被调用的js文件中,面向对象的方式模型输出: module.exports={要调用的函数名称:要调用的函数名称 };

2:在要调用的js文件中模块化引入utils的js文件 var object=require("utils被调用的js文件地址"); 可以输出一下object就能看到被调用的方法了;

例子如下:

要调用的js文件:

小程序的后台获取数据方式get/post具体函数格式如下:wx.request({})

如果屏幕中某元素的内容超过此元素的高度,可设置元素为scroll-view 为滚动状态元素,这样可以做到元素固定高度且元毕拿素内容滚动屏幕不滚动的效果;

scroll-view标签的主要属性分为以下几种:

微信小程序广告轮播元素 图片所在元素/swiper-item>

其中属性有:

图片更改事件:bindchange='imgchange' imagechange()的e.detail.current为当前显示页面的下标值


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12400171.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存