微信小程序实现日历功能


Posted in Javascript onNovember 27, 2018

本文实例为大家分享了微信小程序实现日历功能的具体代码,供大家参考,具体内容如下

效果图:

微信小程序实现日历功能

微信小程序实现日历功能

代码:

<view class="calendar">
 <view class="selectDate">
 <view class="goleft iconfont icon-jianzuo" bindtap="prevMonth"></view>
 <view class="date-wrap">
  {{year}}年{{month}}月
 </view>
 <view class="goright iconfont icon-jianzuo" bindtap="nextMonth"></view>
 </view>
 <view class="week">
 <view wx:for="{{weekArr}}" wx:for-index="index" wx:for-item="item" wx:key="key" style="width:{{param}}px;height:{{param-17}}px;line-height:{{param-17}}px">{{item}}</view>
 </view>
 <view class="date" style='width: {{ param * 7 }}px;'>
 <block wx:for="{{dateArr}}" wx:for-index="index" wx:for-item="item" wx:key="key">
  <view style="{{index ==0?'margin-left:'+ param *firstDay +'px;':''}}width:{{param}}px;height:{{param-10}}px;line-height:{{param-10}}px;" class="{{index+1==day?'today':''}} {{index+1==day&&isClock?'clockOn':''}}"><view class="day">{{item}}</view></view>
 </block>
 </view>
</view><!--end calendar-->
data: {
 year:'',
 month:'',
 day:'',
 weekArr: ['日', '一', '二', '三', '四', '五','六'],
 dateArr:[],
 firstDay:'',
 lastDay:'',
 param:null,
 clockNum:3,
 },
getDate: function () { //获取当月日期
 var mydate = new Date();
 var year = mydate.getFullYear();
 var month = mydate.getMonth();
 var months = month + 1;
 this.data.year = year;
 this.data.month = months;
 this.data.day = mydate.getDate();
 var fist = new Date(year, month, 1);
 this.data.firstDay = fist.getDay();
 var last = new Date(year, months, 0); 
 this.data.lastDay = last.getDate();

 this.setData({
  year: this.data.year,
  month: this.data.month,
  day: this.data.day,
  firstDay: this.data.firstDay,
  lastDay: this.data.lastDay
 })
 console.log("今天:" + this.data.day);
 },
 setDate: function () {
 for (var i = 1; i < this.data.lastDay + 1; i++) {
  this.data.dateArr.push(i);
 }
 this.setData({
  dateArr: this.data.dateArr,
  firstDay: this.data.firstDay
 })
 },
 prevMonth:function(){ //上一月
 var months="";
 var years="";
 if(this.data.month ==1){
  years=this.data.year-1
  this.data.month=12;
  months=this.data.month;
 }else{
  years=this.data.year;
  months = this.data.month - 1;
 }
 
 var first = new Date(years, months-1, 1);
 this.data.firstDay = first.getDay();
 var last = new Date(years, months, 0);
 this.data.lastDay = last.getDate();
 
 this.setData({
  month: months,
  year:years,
  firstDay: this.data.firstDay,
  lastDay: this.data.lastDay
 })

 this.data.dateArr = [];
 for (var i = 1; i < this.data.lastDay + 1; i++) {
  this.data.dateArr.push(i);
 }
 this.setData({
  dateArr: this.data.dateArr
 })
 },
 nextMonth:function(){ //下一月
 var months="";
 var years="";
 if(this.data.month== 12){
  this.data.month=0;
  months = this.data.month;
  years = this.data.year+1;
 }else{
  months = this.data.month+1;
  years = this.data.year;
 }
 var months = this.data.month + 1;
 var first = new Date(years, months-1,1);
 this.data.firstDay= first.getDay();
 var last = new Date(years,months,0);
 this.data.lastDay= last.getDate();
 this.setData({
  month: months,
  year:years,
  firstDay:this.data.firstDay,
  lastDay:this.data.lastDay
 })

 this.data.dateArr = [];
 for (var i = 1; i < this.data.lastDay + 1; i++) {
  this.data.dateArr.push(i);
 }
 this.setData({
  dateArr: this.data.dateArr
 })
 },
onLoad: function (options) {
 this.getDate();
 this.setDate();
 var res = wx.getSystemInfoSync();
 this.setData({
  param:res.windowHeight/12,
 })
 },

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

Javascript 相关文章推荐
菜鸟学习JavaScript小实验之函数引用
Nov 17 Javascript
40款非常有用的 jQuery 插件推荐(系列一)
Dec 21 Javascript
基于jQuery的动态增删改查表格信息,可左键/右键提示(原创自Zjmainstay)
Jul 31 Javascript
浅析jQuery对select操作小结(遍历option,操作option)
Jul 04 Javascript
上传图片js判断图片尺寸和格式兼容IE
Sep 01 Javascript
很酷的星级评分系统原生JS实现
Aug 25 Javascript
JS中IP地址与整数相互转换的实现代码
Apr 10 Javascript
JS实现电商放大镜效果
Aug 24 Javascript
解决angular2在双向数据绑定时[(ngModel)]无法使用的问题
Sep 13 Javascript
微信小程序bindinput与bindsubmit的区别实例分析
Apr 17 Javascript
微信小程序如何自定义table组件
Jun 29 Javascript
vue项目中使用particles实现粒子背景效果及遇到的坑(按钮没有点击响应)
Feb 11 Javascript
微信小程序实现打卡日历功能
Sep 21 #Javascript
微信小程序实现时间预约功能
Nov 27 #Javascript
微信小程序使用component自定义toast弹窗效果
Nov 27 #Javascript
微信小程序自定义底部导航带跳转功能
Nov 27 #Javascript
koa2使用ejs和nunjucks作为模板引擎的使用
Nov 27 #Javascript
jQuery点击页面其他部分隐藏下拉菜单功能
Nov 27 #jQuery
js replace替换字符串同时替换多个方法
Nov 27 #Javascript
You might like
SONY SRF-22W(33W)的电路分析和维修案例
2021/03/02 无线电
PHP5中的this,self和parent关键字详解教程
2007/03/19 PHP
PHP callback函数使用方法和注意事项
2015/01/23 PHP
在Mac OS上搭建Nginx+PHP+MySQL开发环境的教程
2015/12/21 PHP
让回调函数 showResponse 也带上参数的代码
2007/08/13 Javascript
基于jQuery的图片大小自动适应实现代码
2010/11/17 Javascript
jQuery EasyUI API 中文文档 - Form表单
2011/10/06 Javascript
js实现横向百叶窗效果网页切换动画效果的方法
2015/03/02 Javascript
JS实现的不规则TAB选项卡效果代码
2015/09/18 Javascript
AngularJS实现表单手动验证和表单自动验证
2015/12/09 Javascript
微信小程序 图片上传实例详解
2017/05/05 Javascript
vue.js源代码core scedule.js学习笔记
2017/07/03 Javascript
JS动态修改网页body的背景色实例代码
2017/10/07 Javascript
Vue进度条progressbar组件功能
2018/04/17 Javascript
Vue.js实现的计算器功能完整示例
2018/07/11 Javascript
微信小程序实用代码段(收藏版)
2019/12/17 Javascript
BootStrap前端框架使用方法详解
2020/02/26 Javascript
使用 Python 获取 Linux 系统信息的代码
2014/07/13 Python
Python的另外几种语言实现
2015/01/29 Python
Python批量按比例缩小图片脚本分享
2015/05/21 Python
Python 序列的方法总结
2016/10/18 Python
influx+grafana自定义python采集数据和一些坑的总结
2018/09/17 Python
Python递归函数特点及原理解析
2020/03/04 Python
python微信公众号开发简单流程实现
2020/03/09 Python
JD Sports意大利:英国篮球和运动时尚的领导者
2017/10/29 全球购物
Currentbody澳大利亚:美容仪专家
2019/11/11 全球购物
娱乐地球:Entertainment Earth
2020/01/08 全球购物
房地产出纳岗位职责
2013/12/01 职场文书
信用卡工资证明范本
2014/10/17 职场文书
工作证明书
2015/06/15 职场文书
大学生社会服务心得体会
2016/01/22 职场文书
培训心得体会怎么写
2016/01/25 职场文书
python正则表达式re.search()的基本使用教程
2021/05/21 Python
SpringBoot读取Resource下文件的4种方法
2021/07/02 Java/Android
Python OpenCV超详细讲解基本功能
2022/04/02 Python
Java 多线程协作作业之信号同步
2022/05/11 Java/Android