微信小程序时间标签和时间范围的联动效果


Posted in Javascript onFebruary 15, 2019

本文实例为大家分享了微信小程序时间标签和时间范围联动的具体代码,供大家参考,具体内容如下

微信小程序时间标签和时间范围的联动效果

最近忙于一个有关数据管理的微信小程序,遇到了上图情况,虽然很简单,还是整理一下。若有错误,请广大朋友们指正。

使用微信小程序组件radio-group、picker,用wxss对radio按照需求进行重构,picker里边的start和end时间是根据radio来显示的。将start、end时间放在data里,radio发生改变时,改变data中的时间。当picker中的值发生改变时,如果时间范围已经超出了radio中的范围,需要对radio的显示进行实时修改。

话不多说,接下来上代码。

index.wxml

<view class="con_screen">
 <text class="cons_ti">日期范围</text>
 <!-- 单选时间 -->
 <radio-group class="radio-group" bindchange="radioCheckedChange">
  <block >
  <label class="cons_radio {{radioCheckVal==1?'active':''}}" >
   <radio value="1" hidden="true"/>
   <text>今日</text>
  </label> 
  <label class="cons_radio {{radioCheckVal==4?'active':''}}" >
   <radio value="4" hidden="true" />
   <text>近7日</text>
  </label> 
  <label class="cons_radio {{radioCheckVal==6?'active':''}}" >
   <radio value="6" hidden="true"/>
   <text>近30日</text>
  </label>  
  </block>
 </radio-group>
 <!-- 时间段 -->
 <view class="picker_group">
  <picker mode="date" value="{{date}}" start="2015-09-01" end="{{date2}}" bindchange="bindDateChange">
  <view class="picker">
   {{date}}
   <image src="../../image/home_zsr_icon.png"></image>
  </view>
  </picker>
  到
  <picker mode="date" value="{{date2}}" start="{{date}}" end="2018-01-24" bindchange="bindDateChange2">
  <view class="picker">
   {{date2}}
   <image src="../../image/home_zsr_icon.png"></image>
  </view>
  </picker>  
 </view>
  
 </view>

index.wxss

.radio-group{
 display: inline-block;
}
.cons_radio{
 margin-left: 30rpx;
}
.cons_radio text{
 font-size: 26rpx;
 color: #c8c8c8;
 height: 40rpx;
 /* width: 93rpx; */
 border: #c8c8c8 solid 2rpx;
 padding:0 20rpx;
 text-align: center;
 line-height: 40rpx;
 display: inline-block;
 border-radius: 20rpx;
}
/* 黄色 */
.cons_radio.active text{
 color: #F5A623;
 border-color: #F5A623;
}
/* 红色 */
.cons_radio.activered text{
 color: #FA2B21;
 border-color: #FA2B21;
}
/* 蓝色 */
.cons_radio.activeblue text{
 color: #4AAFDD;
 border-color: #4AAFDD;
}
/* 黄绿色 */
.cons_radio.activeyg text{
 color: #BABC1A;
 border-color: #BABC1A;
}
 
/* 日期选择 */
.picker_group{
 display: block;
 font-size: 28rpx;
 color: #c8c8c8;
 margin-left: 20rpx;
 margin-top: 15rpx;
}
.picker_group picker{
 display: inline-block;
 margin:0 20rpx 0 20rpx;
 position: relative;
 color: #232323;
}
.picker_group picker image{
 width: 20rpx;
 height: 20rpx;
}
.cons_zsr{
 display: block;
 font-size: 32rpx;
 color: #232323;
 margin-left: 40rpx;
 margin-bottom: 15rpx;
}
.cons_zsr picker image{
 width: 30rpx;
 height: 30rpx;
}

index.js

Page({
 data:{
 page:'',
 Loading:false,
 isLogin:false,
 radioCheckVal:0,//收益占比单选
 date: '2015-09-01',//收益占比时间段起始时间
 date2:'2018-01-24',//收益占比时间段终止时间
 }, 
 // 收益占比单选时间 ring
 radioCheckedChange(e){ 
 let that=this; 
 that.setData({ 
  radioCheckVal:e.detail.value 
 }) 
 console.log(that.data.radioCheckVal)
 if(that.data.radioCheckVal=='1'){
  that.setData({
  date:timedate.formatDate(now),
  date2:timedate.formatDate(now),
  })
  // console.log(that.data.date+'------'+that.data.date2)
  that.timeFn(that.data.arrayindex,that.data.date,that.data.date2)
 }
 if(that.data.radioCheckVal=='4'){
  that.setData({
  date:timedate.sevenDays().t2,
  date2:timedate.sevenDays().t1,
  })
  // console.log(that.data.date+'------'+that.data.date2)
  that.timeFn(that.data.arrayindex,that.data.date,that.data.date2)
 }
 if(that.data.radioCheckVal=='6'){
  that.setData({
  date:timedate.thirtyDays().t2,
  date2:timedate.thirtyDays().t1,
  })
  // console.log(that.data.date+'------'+that.data.date2)
  that.timeFn(that.data.arrayindex,that.data.date,that.data.date2)
 }
 },
 // 收益占比时间段选择
 bindDateChange(e){
 let that=this;
 console.log(e.detail.value)
 that.setData({
  date: e.detail.value,
  radioCheckVal:0,
 })
 that.timeFn(that.data.arrayindex,that.data.date,that.data.date2)
 },
 bindDateChange2(e){
 let that=this;
 that.setData({
  date2: e.detail.value,
  radioCheckVal:0,
 })
 that.timeFn2(that.data.arrayindex,that.data.date,that.data.date2)
 },

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
一组JS创建和操作表格的函数集合
May 07 Javascript
JavaScript 权威指南(第四版) 读书笔记
Aug 11 Javascript
jQuery 页面 Mask实现代码
Jan 09 Javascript
让IE6支持min-width和max-width的方法
Jun 25 Javascript
javascript 禁用IE工具栏,导航栏等等实现代码
Apr 01 Javascript
判断JS对象是否拥有某种属性的两种方式
Dec 02 Javascript
JQuery动画animate的stop方法使用详解
May 09 Javascript
基于javascript实现漂亮的页面过渡动画效果附源码下载
Oct 26 Javascript
总结JavaScript三种数据存储方式之间的区别
May 03 Javascript
vue实现同一个页面可以有多个router-view的方法
Sep 20 Javascript
JavaScript变速动画函数封装添加任意多个属性
Apr 03 Javascript
解决Layui 表格自适应高度的问题
Nov 15 Javascript
微信小程序实现商品属性联动选择
Feb 15 #Javascript
微信小程序实现购物页面左右联动
Feb 15 #Javascript
微信小程序基于picker实现级联菜单
Feb 15 #Javascript
微信小程序实现多个按钮的颜色状态转换
Feb 15 #Javascript
详解react-refetch的使用小例子
Feb 15 #Javascript
小程序实现多列选择器
Feb 15 #Javascript
jQuery实现经典的网页3D轮播图封装功能【附源码下载】
Feb 15 #jQuery
You might like
Window 7/XP 安装Apache 2.4与PHP 5.4 的过程详解
2013/06/02 PHP
更改localhost为其他名字的方法
2014/02/10 PHP
PHPMailer的主要功能特点和简单使用说明
2014/02/17 PHP
PHP中使用smarty生成静态文件的例子
2014/04/24 PHP
Yii实现显示静态页的方法
2016/04/25 PHP
PHP针对中英文混合字符串长度判断及截取方法示例
2017/03/31 PHP
php和redis实现秒杀活动的流程
2019/07/17 PHP
JS与框架页的操作代码
2010/01/17 Javascript
JS 无限级 Select效果实现代码(json格式)
2011/08/30 Javascript
js不完美解决click和dblclick事件冲突问题
2012/07/16 Javascript
Ext4.2的Ext.grid.plugin.RowExpander无法触发事件解决办法
2014/08/15 Javascript
JavaScript操作Cookie方法实例分析
2015/05/27 Javascript
angularjs 页面自适应高度的方法
2018/01/17 Javascript
vue实现tab切换外加样式切换方法
2018/03/16 Javascript
jQuery 实现批量提交表格多行数据的方法
2018/08/09 jQuery
微信小程序中悬浮窗功能的实现代码
2019/08/02 Javascript
vue之a-table中实现清空选中的数据
2019/11/07 Javascript
JS实现字体背景跑马灯
2020/01/06 Javascript
Vue 打包体积优化方案小结
2020/05/20 Javascript
[01:00:44]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#1COL VS Alliance第三局
2016/03/04 DOTA
python写的一个文本编辑器
2014/01/23 Python
Python通过select实现异步IO的方法
2015/06/04 Python
Python数据结构之图的应用示例
2018/05/11 Python
用uWSGI和Nginx部署Flask项目的方法示例
2019/05/05 Python
django drf框架自带的路由及最简化的视图
2019/09/10 Python
pyqt5 QScrollArea设置在自定义侧(任何位置)
2019/09/25 Python
PyQt5中向单元格添加控件的方法示例
2020/03/24 Python
mac系统下安装pycharm、永久激活、中文汉化详细教程
2020/11/24 Python
英国香水店:The Perfume Shop
2017/03/27 全球购物
Crabtree & Evelyn欧盟:豪华洗浴、身体和护发
2021/03/09 全球购物
职工趣味运动会方案
2014/02/10 职场文书
学校欢迎标语
2014/06/18 职场文书
英语系毕业生求职信
2014/07/13 职场文书
2016年党风廉政建设承诺书
2016/03/25 职场文书
范文之农村基层党建工作报告
2019/10/24 职场文书
nginx如何将http访问的网站改成https访问
2021/03/31 Servers