我的编程空间,编程开发者的网络收藏夹
学习永远不晚

【无标题】小程序picker实现时间日期的选择(精确到时分)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

【无标题】小程序picker实现时间日期的选择(精确到时分)

文章出处:(6条消息) [微信小程序] 原生小程序picker组件实现时间日期的选择_小程序 picker date_iChangebaobao的博客-CSDN博客

 {{time}} 

js文件

const DatePickerUtil = require('../../utils/DatePicker.js')Page({  data: {    time: '选择预约时间',    multiArray: [],//piker的item项    multiIndex: [],//当前选择列的下标    year: '',//选择的年    month: '',//选择的月    day: '',//选择的日    hour: '',//选择的时    minute: '',//选择的分  },  onShow: function () {    //获取 DatePickerUtil 工具下的方法    var loadPickerData = DatePickerUtil.loadPickerData()    var getCurrentDate = DatePickerUtil.getCurrentDate()    var GetMultiIndex = DatePickerUtil.GetMultiIndex()    //这里写的是为了记录当前时间    let year = parseInt(getCurrentDate.substring(0, 4));    let month = parseInt(getCurrentDate.substring(5, 7));    let day = parseInt(getCurrentDate.substring(8, 10));    let hour = parseInt(getCurrentDate.substring(11, 13));    let minute = parseInt(getCurrentDate.substring(14, 16));    this.setData({      multiArray: loadPickerData,//picker数组赋值,格式 [years, months, days, hours, minutes]      multiIndex: GetMultiIndex,//设置pickerIndex,[0,0,0,0,0]      time: getCurrentDate, //设置当前时间 ,currentYears+'-'+mm+'-'+dd+' '+hh+':'+min      year: year,//记录选择的年      month: month,//记录选择的月      day: day,//记录选择的日      hour: hour,//记录选择的时      minute: minute,//记录选择的分     });  },  bindMultiPickerChange: function (e) { //时间日期picker选择改变后,点击确定     // console.log('picker发送选择改变,携带值为', e.detail.value)    this.setData({      multiIndex: e.detail.value    })    const index = this.data.multiIndex; // 当前选择列的下标    const year = this.data.multiArray[0][index[0]];    const month = this.data.multiArray[1][index[1]];    const day = this.data.multiArray[2][index[2]];    const hour = this.data.multiArray[3][index[3]];    const minute = this.data.multiArray[4][index[4]];    // console.log(`${year}-${month}-${day} ${hour}:${minute}`);     this.setData({      time: year + month + day + ' ' + hour.replace('时', '') + ':' + minute.replace('分', ''),      year: year, //记录选择的年      month: month, //记录选择的月      day: day, //记录选择的日      hour: hour, //记录选择的时      minute: minute, //记录选择的分     })    //console.log(this.data.time);   },  bindMultiPickerColumnChange: function (e) { //监听picker的滚动事件    // console.log('修改的列为', e.detail.column, ',值为', e.detail.value);    let getCurrentDate = DatePickerUtil.getCurrentDate();//获取现在时间      let currentYear = parseInt(getCurrentDate.substring(0, 4));    let currentMonth = parseInt(getCurrentDate.substring(5, 7));    let currentDay = parseInt(getCurrentDate.substring(8, 10));    let currentHour = parseInt(getCurrentDate.substring(11, 13));    let currentMinute = parseInt(getCurrentDate.substring(14, 16));    if (e.detail.column == 0) {//修改年份列       let yearSelected = parseInt(this.data.multiArray[e.detail.column][e.detail.value]);//当前选择的年份      this.setData({        multiIndex: [0, 0, 0, 0, 0],//设置pickerIndex        year: yearSelected //当前选择的年份      });      if (yearSelected == currentYear) {//当前选择的年份==当前年份          var loadPickerData = DatePickerUtil.loadPickerData();        this.setData({          multiArray: loadPickerData,//picker数组赋值          multiIndex: [0, 0, 0, 0, 0] //设置pickerIndex        });      } else {  // 选择的年份!=当前年份         // 处理月份        let monthArr = DatePickerUtil.loadMonths(1, 12)        // 处理日期        let dayArr = DatePickerUtil.loadDays(currentYear, currentMonth, 1)        // 处理hour        let hourArr = DatePickerUtil.loadHours(0, 24);        // 处理minute        let minuteArr = DatePickerUtil.loadMinutes(0, 60)        // 给每列赋值回去        this.setData({          ['multiArray[1]']: monthArr,          ['multiArray[2]']: dayArr,          ['multiArray[3]']: hourArr,          ['multiArray[4]']: minuteArr        });      }    }    if (e.detail.column == 1) {//修改月份列      let mon = parseInt(this.data.multiArray[e.detail.column][e.detail.value]); //当前选择的月份      this.setData({        month: mon  // 记录当前列      })      if (mon == currentMonth) {//选择的月份==当前月份         if (this.data.year == currentYear) {          // 处理日期          let dayArr = DatePickerUtil.loadDays(currentYear, mon, currentDay)          // 处理hour          let hourArr = DatePickerUtil.loadHours(currentHour, 24);          // 处理minute          let minuteArr = DatePickerUtil.loadMinutes(currentMinute, 60)          this.setData({            ['multiArray[2]']: dayArr,            ['multiArray[3]']: hourArr,            ['multiArray[4]']: minuteArr          })        } else {          // 处理日期          let dayArr = DatePickerUtil.loadDays(this.data.year, mon, 1)          // 处理hour          let hourArr = DatePickerUtil.loadHours(0, 24);          // 处理minute          let minuteArr = DatePickerUtil.loadMinutes(0, 60)          this.setData({            ['multiArray[2]']: dayArr,            ['multiArray[3]']: hourArr,            ['multiArray[4]']: minuteArr          });        }      } else {  // 选择的月份!=当前月份         // 处理日期        let dayArr = DatePickerUtil.loadDays(this.data.year, mon, 1) // 传入当前年份,当前选择的月份去计算日        // 处理hour        let hourArr = DatePickerUtil.loadHours(0, 24);        // 处理minute        let minuteArr = DatePickerUtil.loadMinutes(0, 60)console.log(dayArr,'日期');        this.setData({          ['multiArray[2]']: dayArr,          ['multiArray[3]']: hourArr,          ['multiArray[4]']: minuteArr        });      }    }    if (e.detail.column == 2) {//修改日      let dd = parseInt(this.data.multiArray[e.detail.column][e.detail.value]);//当前选择的日      this.setData({        day: dd      })      if (dd == currentDay) {//选择的日==当前日        if (this.data.year == currentYear && this.data.month == currentMonth) {//选择的是今天           // 处理hour          let hourArr = DatePickerUtil.loadHours(currentHour, 24);          // 处理minute          let minuteArr = DatePickerUtil.loadMinutes(currentMinute, 60)          this.setData({            ['multiArray[3]']: hourArr,            ['multiArray[4]']: minuteArr          });        } else { //选择的不是今天           // 处理hour          let hourArr = DatePickerUtil.loadHours(0, 24);          // 处理minute          let minuteArr = DatePickerUtil.loadMinutes(0, 60)          this.setData({            ['multiArray[3]']: hourArr,            ['multiArray[4]']: minuteArr          });        }      } else {  // 选择的日!=当前日         // 处理hour        let hourArr = DatePickerUtil.loadHours(0, 24);        // 处理minute        let minuteArr = DatePickerUtil.loadMinutes(0, 60)        this.setData({          ['multiArray[3]']: hourArr,          ['multiArray[4]']: minuteArr        });      }    }    if (e.detail.column == 3) {//修改时      let hh = parseInt(this.data.multiArray[e.detail.column][e.detail.value]); //当前选择的时      this.setData({        hour: hh      })      if (hh == currentHour) {//选择的时==当前时         if (this.data.year == currentYear && this.data.month == currentMonth && this.data.month == currentMonth) {   // 选择的是今天          // 处理minute          let minuteArr = DatePickerUtil.loadMinutes(currentMinute, 60)          this.setData({            ['multiArray[4]']: minuteArr          });        } else { // 选择的不是今天          // 处理minute          let minuteArr = DatePickerUtil.loadMinutes(0, 60)          this.setData({            ['multiArray[4]']: minuteArr          });        }      } else {//选择的时!=当前时         // 处理minute        let minuteArr = DatePickerUtil.loadMinutes(0, 60)        this.setData({          ['multiArray[4]']: minuteArr        });      }    }    var data = {      multiArray: this.data.multiArray,      multiIndex: this.data.multiIndex    };    data.multiIndex[e.detail.column] = e.detail.value; //将值赋回去    this.setData(data);  //将值赋回去  }})

DatePicker.js文件

const formatNumber = n => {  n = n.toString()  return n[1] ? n : '0' + n}function getCurrentDate(){// 获取当前时间  let date = new Date();     let currentYears=date.getFullYear();  let currentMonths=date.getMonth()+1;  let currentDay=date.getDate();  let currentHours=date.getHours();  let currentMinute=date.getMinutes();       var year=[currentYears].map(formatNumber)  var mm=[currentMonths].map(formatNumber)  var dd=[currentDay].map(formatNumber)  var hh=[currentHours].map(formatNumber)  var min=[currentMinute].map(formatNumber)      return year+'年'+mm+'月'+dd+'日'+hh+':'+min;}function GetMultiIndex(){ //一点开picker的选中设置     return [0,0,0,0,0]; //现在全部列,默认选第一个选项,其实这一步多余,可以直接在data里面定义 }  function loadYears(startYear,endYear){//获取年份     let years=[];  for (let i = startYear; i <= endYear; i++) {    years.push("" + i+"年");  }   // console.log(years,'years');  return years;//返回年份数组 }function loadMonths(startMonth,endMonth){//获取月份  // console.log(startMonth,endMonth,'startMonth,endMonth');      let months=[];  for (let i = startMonth; i <= endMonth; i++) {    if (i < 10) {      i = "0" + i;    }    months.push("" + i+"月");  }   // console.log(months,'months');  return months;//返回月份数组 }function loadDays(yearSelected,selectedMonths,startDay){ //获取日期    //  console.log(currentYears,selectedMonths,startDay,'111');    let days=[];    if (selectedMonths == 1 || selectedMonths == 3 || selectedMonths == 5 || selectedMonths == 7 || selectedMonths == 8 || selectedMonths == 10 || selectedMonths == 12) { //判断31天的月份,可以用正则简化      for (let i = startDay; i <= 31; i++) {        if (i < 10) {          i = "0" + i;        }        days.push("" + i+'日');      }     } else if (selectedMonths == 4 || selectedMonths == 6 || selectedMonths == 9 || selectedMonths == 11) { //判断30天的月份      for (let i = startDay; i <= 30; i++) {        if (i < 10) {          i = "0" + i;        }        days.push("" + i+'日');      }     } else if (selectedMonths == 2) { //判断2月份天数      console.log('2月');      let year = yearSelected       console.log(year,'year');      if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0) {//闰年        for (let i = startDay; i <= 29; i++) {          if (i < 10) {            i = "0" + i;          }          days.push("" + i+'日');        }      } else {//不是闰年        for (let i = startDay; i <= 28; i++) {          if (i < 10) {            i = "0" + i;          }          days.push("" + i+'日');        }       }    }    console.log(days,'days');    return days;//返回日期数组}function loadHours(startHour,endHour){//获取小时      let hours=[];   for (let i = startHour; i < endHour ; i++) {    if (i < 10) {//看需求要不要加在前面+‘0’      i = "0" + i;    }    hours.push("" + i+"时");  }  return hours;//返回小时数组 }function loadMinutes(startMinute,endMinute){//获取分钟     let minutes=[];  for (let i = startMinute; i < endMinute ; i++) {   if (i < 10) {     i = "0" + i;   }   minutes.push("" + i+"分"); } return minutes;//返回分钟数组 }//我没有用到秒,可以参考分钟的写法function loadPickerData(){ //将Picker初始数据,开始时间设置为当前时间  let date1 = new Date();     let currentYears=date1.getFullYear();  let currentMonths=date1.getMonth()+1;  let currentDay=date1.getDate();  let currentHours=date1.getHours();  let currentMinute=date1.getMinutes();      // 下面调用 自定义方法   //获取年份  loadYears(startYear,endYear)    //获取月份  loadMonths(startMonth,endMonth)  //获取日期  loadDays(currentYears,currentMonths,startDay)  //获取小时  loadHours(startHour,endHour)  //获取分钟  loadMinutes(startMinute,endMinute)    let years = loadYears(currentYears,date1.getFullYear() + 100)  //客户说只能预约两年内,+1  let months = loadMonths(currentMonths,12)     let days = loadDays(currentYears,currentMonths,currentDay)    let hours = loadHours(currentHours,24)    let minutes =  loadMinutes(currentMinute,60)    return [years, months, days, hours, minutes]} //导出module.exports = {  loadPickerData:loadPickerData,  getCurrentDate:getCurrentDate,  GetMultiIndex:GetMultiIndex,  loadYears:loadYears,  loadMonths:loadMonths,  loadDays:loadDays,  loadHours:loadHours,  loadMinutes:loadMinutes}

来源地址:https://blog.csdn.net/m0_45215325/article/details/131556168

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

【无标题】小程序picker实现时间日期的选择(精确到时分)

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

uniapp 小程序 picker 日期时间段选择(精确到年月日时分+周几)

效果图: picker时间选择器 精确到年月日时分+周几 需要引入moment.js,有可能引入后在项目内会报错,可以考虑把选择日期作为一个组件引入 1、timepage.vue组件封装 template>view>p
2023-08-24

小程序日期时间选择器怎么实现

今天小编给大家分享一下小程序日期时间选择器怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。  要用到picker组件,
2023-06-26

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录