微信小程序实现日历功能


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 相关文章推荐
Flash对联广告的关闭按钮讨论
Jan 30 Javascript
javascript 二分法(数组array)
Apr 24 Javascript
js捕获鼠标滚轮事件代码
Dec 16 Javascript
javascript动态向网页中添加表格实现代码
Feb 19 Javascript
一起学写js Calender日历控件
Apr 14 Javascript
深入理解JS正则表达式---分组
Jul 18 Javascript
Vue声明式渲染详解
May 17 Javascript
vue-router 中router-view不能渲染的解决方法
May 23 Javascript
微信小程序 获取javascript 里的数据
Aug 17 Javascript
vue实现标签云效果的方法详解
Aug 28 Javascript
vue3如何优雅的实现移动端登录注册模块
Mar 29 Vue.js
Rust中的Struct使用示例详解
Aug 14 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
php adodb操作mysql数据库
2009/03/19 PHP
用PHP的超级变量$_POST获取HTML表单(HTML Form) 数据
2011/05/07 PHP
PHP实现GIF图片验证码
2015/11/04 PHP
PHP基于单例模式实现的数据库操作基类
2016/01/15 PHP
PHP调用API接口实现天气查询功能的示例
2017/09/21 PHP
JavaScript 大数据相加的问题
2011/08/03 Javascript
ASP.NET jQuery 实例7 通过jQuery来获取DropDownList的Text/Value属性值
2012/02/03 Javascript
浅析js中取绝对值的2种方法
2013/07/09 Javascript
js选项卡的实现方法
2015/02/09 Javascript
JS实现文档加载完成后执行代码
2015/07/09 Javascript
Seajs 简易文档 提供简单、极致的模块化开发体验
2016/04/13 Javascript
js实现右键菜单功能
2016/11/28 Javascript
详解Vue.js Mixins 混入使用
2017/09/15 Javascript
Angular 开发学习之Angular CLI的安装使用
2017/12/31 Javascript
p5.js入门教程之鼠标交互的示例
2018/03/16 Javascript
Vue表单类的父子组件数据传递示例
2018/05/03 Javascript
Vue CLI3.0中使用jQuery和Bootstrap的方法
2019/02/28 jQuery
python处理图片之PIL模块简单使用方法
2015/05/11 Python
Python实现图片滑动式验证识别方法
2017/11/09 Python
Python中pandas模块DataFrame创建方法示例
2018/06/20 Python
python执行精确的小数计算方法
2019/01/21 Python
python输出带颜色字体实例方法
2019/09/01 Python
基于Pyinstaller打包Python程序并压缩文件大小
2020/05/28 Python
django 将自带的数据库sqlite3改成mysql实例
2020/07/09 Python
日本AOKI官方商城:AOKI西装
2020/06/11 全球购物
几个SQL的面试题
2014/03/08 面试题
SQL里面IN比较快还是EXISTS比较快
2012/07/19 面试题
C#面试问题
2016/07/29 面试题
《莫高窟》教学反思
2014/02/25 职场文书
早会主持词
2014/03/17 职场文书
交通事故协议书范文
2014/10/23 职场文书
学生党员检讨书范文
2014/12/27 职场文书
人事局接收函
2015/01/31 职场文书
机修车间主任岗位职责
2015/04/08 职场文书
2015年小学总务工作总结
2015/07/21 职场文书
Rust 连接 PostgreSQL 数据库的详细过程
2022/01/22 PostgreSQL