微信小程序实现日历功能


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 相关文章推荐
web 页面分页打印的实现
Jun 22 Javascript
jQuery 自动增长的文本输入框实现代码
Apr 02 Javascript
js 静态动态成员 and 信息的封装和隐藏
May 29 Javascript
jQuery EasyUI API 中文文档 - Tabs标签页/选项卡
Oct 01 Javascript
JS常用函数使用指南
Nov 23 Javascript
自定义require函数让浏览器按需加载Js文件
Nov 24 Javascript
Angular5.0 子组件通过service传递值给父组件的方法
Jul 13 Javascript
快速解决处理后台返回json数据格式的问题
Aug 07 Javascript
Layui 设置select下拉框自动选中某项的方法
Aug 14 Javascript
JS/jQuery实现超简单的Table表格添加,删除行功能示例
Jul 31 jQuery
JQuery常用简单动画操作方法回顾与总结
Dec 07 jQuery
Vue多选列表组件深入详解
Mar 02 Vue.js
微信小程序实现打卡日历功能
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数据饼图效果实现代码
2011/11/23 PHP
如何使用php判断所处服务器操作系统的类型
2013/06/20 PHP
PHP基于phpqrcode生成带LOGO图像的二维码实例
2015/07/10 PHP
php注册审核重点解析(数据访问)
2017/05/23 PHP
PHP框架laravel的.env文件配置教程
2017/06/07 PHP
jquery调用asp.net 页面后台的实现代码
2011/04/27 Javascript
JavaScript 布尔操作符解析  &amp;&amp; || !
2012/08/10 Javascript
JS判断字符串包含的方法
2015/05/05 Javascript
js+html5通过canvas指定开始和结束点绘制线条的方法
2015/06/05 Javascript
jquery.zclip轻量级复制失效问题
2017/01/08 Javascript
jquery 实时监听输入框值变化的完美方法(必看)
2017/01/26 Javascript
全新打包工具parcel零配置vue开发脚手架
2018/01/11 Javascript
浅析Angular19 自定义表单控件
2018/01/31 Javascript
vue使用jsonp抓取qq音乐数据的方法
2018/06/21 Javascript
浅谈es6中的元编程
2020/12/01 Javascript
[46:16]2018DOTA2亚洲邀请赛3月30日 小组赛B组 iG VS VP
2018/03/31 DOTA
详解Python中heapq模块的用法
2016/06/28 Python
Python爬虫代理IP池实现方法
2017/01/05 Python
关于Python中空格字符串处理的技巧总结
2017/08/10 Python
Python numpy生成矩阵、串联矩阵代码分享
2017/12/04 Python
Python通过属性手段实现只允许调用一次的示例讲解
2018/04/21 Python
PyQt5 closeEvent关闭事件退出提示框原理解析
2020/01/08 Python
python 解决tqdm模块不能单行显示的问题
2020/02/19 Python
python中如何写类
2020/06/29 Python
Python读写csv文件流程及异常解决
2020/10/20 Python
numpy实现RNN原理实现
2021/03/02 Python
HTML5本地存储和本地数据库实例详解
2017/09/05 HTML / CSS
Maje德国官网:法国女性成衣品牌
2017/02/10 全球购物
波兰品牌鞋履在线商店:Eastend.pl
2020/01/11 全球购物
Aosom西班牙:家具在线商店
2020/06/11 全球购物
思想政治自我鉴定
2013/10/06 职场文书
学校爱心捐款倡议书
2014/05/13 职场文书
2014党员整改措施思想汇报
2014/10/07 职场文书
初二物理教学反思
2016/02/19 职场文书
go 原生http web 服务跨域restful api的写法介绍
2021/04/27 Golang
使用python创建股票的时间序列可视化分析
2022/03/03 Python