小程序实现日历打卡功能

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

一、效果图展示

老惯例,先上效果图

二、实现思路

1、日历展示

例如下图中:

2021月7月打卡日历页面,共35个日期数据,上月残余4天+本月31天;

2021月6月打卡日历页面,共35个日期数据,上月残余2天+本月30天+下月残余3天;

2021月5月打卡日历页面,共42个日期数据,上月残余6天+本月31天+下月残余5天。

【结论】打卡日历页面存在展示35个或42个日期数据的情况,35个或42个日期数据=当前显示月所有日期数据+上月残余尾部日期+下月残余头部日期。

计算出每个月的日期天数,获取本月1号是周几,上月残余天数=本月1号的星期X的X数(比如,2021年7月1日是星期四,则上月残余4天),假设 a=35-本月天数-上月残余天数。如果a>=0,则下月残余天数=a;如果a<0,则下月残余天数=7+a (比如2021年5月,35-37=-2;7+(-2)=5)

2、打卡功能

打卡实现的功能:可打卡的日期为今日日期或今日日期之前未打卡过的日期。

如图:今日日期为绿色圆形背景,当前点击日期为橙色圆形背景;可打卡时,打卡按钮背景为蓝色,不可打卡时,打卡背景为灰色;√ 代表已打卡。

通过数据库查询当前已打卡的数据,已打卡的数据需要设置打卡按钮禁用标志。打卡按钮禁用的情况(1)页面初始化时,未点击任何日期(2)当前点击的日期在今天之后(3)当前日期在今天之前但已打卡。

点击打卡,记录打卡日期并保存至数据库。

三、代码

1、数据库数据

2、日历组件

【calendar.wxml】

代码里使用了WXS页内脚本,渲染“已打卡”的标志(√)

<view class="calendar">
  <view class='tit'>
    <view class='pre' bindtap='gotoPreMonth'>{{'《'}}</view>
    <view class='current'>{{currentYear}}年{{currentMonth}}月</view>
    <view class='next' bindtap='gotoNextMonth'>{{'》'}}</view>
  </view>
  <view class='w100P showData'>
    <view class="week" style='color: #999'>日</view>
    <view class="week">一</view>
    <view class="week">二</view>
    <view class="week">三</view>
    <view class="week">四</view>
    <view class="week">五</view>
    <view class="week" style='color: #999'>六</view>
  </view>
  <view class='content'>
    <view wx:for="{{allArr}}" wx:key="index" class='itemData' data-current="{{item.month == 'current' ? '1' : '0'}}"
      data-day='{{item.date}}' bindtap='clickDate'>
      <view class="{{item.month == 'current' ? '' : 'gray'}}"
        style="height:44px;width:44px;line-height:30px;{{nowYear==currentYear&&currentMonth==nowMonth&&item.date==nowDate?'color:#fff;background:#33D4C5;border-radius:100px':''}};{{item.month == 'current'&&selectedYear==currentYear&&selectedMonth==currentMonth&&item.date==selectedDate?'color:#fff;background:orange;border-radius:100px':''}} ">
        {{item.date}}
        <view>
          <icon wx:if="{{item.month == 'current'&&dataProcess.filterDate(currentPunchCardDate,item.date)}}" class="icon" color="#F44336" type="success_no_circle" size="15"></icon>
        </view>
      </view>
    </view>
  </view>
  <view class="btn-wrapper" bindtap="gotoToday">
    <button class="btn">回今天</button>
  </view>
  <!-- wxs页面内脚本,在渲染层做数据处理 -->
  <wxs module="dataProcess">
  function filterDate(currentPunchCardDate,date){
    if(currentPunchCardDate.indexOf(date)!==-1){
      return true
  }
  }
  module.exports={
    filterDate:filterDate
  }
  </wxs>
</view>

【calendar.wxss】

.calendar {
  width: 100%;
  background: #fff;
}
 
.pre,
.next {
  color: #33D4C5;
  text-align: center;
  line-height: 20px;
}
 
.calendar .tit {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 40rpx 0;
 
}
 
.current {
  font-size: 32rpx;
  color: #2A2A2A;
}
 
.calendar .tit .current {
  margin: 0 60rpx;
}
 
.showData {
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  padding-left: 25rpx;
  padding-right: 25rpx;
}
 
.showData .week {
  width: 14%;
  height: 70rpx;
  line-height: 70rpx;
  text-align: center;
  flex-shrink: 0;
  font-size: 30rpx;
  color: #2A2A2A;
}
 
.calendar .content {
  display: flex;
  flex-wrap: wrap;
  box-sizing: border-box;
  padding-left: 25rpx;
  padding-right: 25rpx;
}
 
.calendar .content .itemData {
  width: 14.2%;
  height: 90rpx;
  line-height: 90rpx;
  flex-shrink: 0;
  font-size: 30rpx;
  color: #2A2A2A;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
 
.calendar .content .icon {
  position: relative;
  top: -25rpx;
}
 
.calendar .content .gray {
  color: #999;
}
 
.currentSelected {
  color: #fff;
  background: #1CA2FC;
  border-radius: 100px;
}
 
.calendar .btn-wrapper {
  text-align: right;
  background-color: #fff;
  width: 100%;
  padding-bottom: 10rpx;
}
 
.calendar .btn-wrapper .btn {
  border: 1px solid #33D4C5;
  padding: 5rpx;
  width: 95rpx;
  font-size: 21rpx;
  color: #33D4C5;
  border-radius: 20rpx;
  margin-bottom: 15rpx;
  position: relative;
  left: calc(50% - 100rpx);
}

【calendar.js】

Component({
  /**
   * 组件的属性列表
   */
 
  properties: {
    currentPunchCardDate: {
      type: Array,
      value: []
    },
    currentYear: { // 当前页面显示的年
      type: Number,
      value: new Date().getFullYear()
    },
    currentMonth: { // 当前页面显示的年月
      type: Number,
      value: new Date().getMonth() + 1
    },
    nowYear: { // 当前年
      type: Number,
      value: new Date().getFullYear()
    },
    nowMonth: { // 当前月
      type: Number,
      value: new Date().getMonth() + 1
    },
    nowDate: { // 当前日
      type: Number,
      value: new Date().getDate()
    },
 
  },
 
  /**
   * 组件的初始数据
   */
  data: {
    currentMonthDateLen: 0, // 当月天数
    preMonthDateLen: 0, // 当月中,上月多余天数
    allArr: [], // 35个或42个日期数据=当前显示月所有日期数据+上月残余尾部日期+下月残余头部日期
    nowDate: null,
    selectedDate: null, //当前选择日期
    selectedMonth: null, //当前选择月
    selectedYear: null, //当前选择年
  },
  // 用observers监听properties的属性值
  observers: {
    'currentPunchCardDate': function (val) {
      console.log(val)
 
    }
  },
  // 在组件实例刚刚被创建时执行
  created() {},
  // 在组件实例进入页面节点树时执行
  ready() {
    this.getAllArr()
  },
  /**
   * 组件的方法列表
   */
  methods: {
    // 获取某年某月天数:下个月1日-本月1日 
    getDateLen(year, month) {
      let actualMonth = month - 1;
      let timeDistance = new Date(year, month) - new Date(year, actualMonth);
      return timeDistance / (1000 * 60 * 60 * 24);
    },
    // 获取某月1号是周几
    getFirstDateWeek(year, month) {
      // 0-6,0代表周天
      return new Date(year, month - 1, 1).getDay()
    },
    // 上月
    preMonth(year, month) {
      if (month == 1) {
        return {
          year: --year,
          month: 12
        }
      } else {
        return {
          year: year,
          month: --month
        }
      }
    },
    // 下月
    nextMonth(year, month) {
      if (month == 12) {
        return {
          year: ++year,
          month: 1
        }
      } else {
        return {
          year: year,
          month: ++month
        }
      }
    },
    // 获取当月数据,返回数组
    getCurrentArr() {
      let currentMonthDateLen = this.getDateLen(this.data.currentYear, this.data.currentMonth) // 获取当月天数
      let currentMonthDateArr = [] // 定义空数组
      if (currentMonthDateLen > 0) {
        for (let i = 1; i <= currentMonthDateLen; i++) {
          currentMonthDateArr.push({
            month: 'current', // 只是为了增加标识,区分上下月
            date: i
          })
        }
      }
      this.setData({
        currentMonthDateLen
      })
      return currentMonthDateArr
    },
    // 获取当月中,上月多余的日期数据,返回数组
    getPreArr() {
      let preMonthDateLen = this.getFirstDateWeek(this.data.currentYear, this.data.currentMonth) // 当月1号是周几 == 上月残余天数)
      console.log("preMonthDateLen=", preMonthDateLen);
      let preMonthDateArr = [] // 定义空数组
      if (preMonthDateLen > 0) {
        let {
          year,
          month
        } = this.preMonth(this.data.currentYear, this.data.currentMonth) // 获取上月 年、月
        let date = this.getDateLen(year, month) // 获取上月天数
        for (let i = 0; i < preMonthDateLen; i++) {
          preMonthDateArr.unshift({ // 尾部追加
            month: 'pre', // 只是为了增加标识,区分当、下月
            date: date
          })
          date--
        }
      }
      this.setData({
        preMonthDateLen
      })
      return preMonthDateArr
    },
    // 获取当月中,下月多余的日期数据,返回数组
    getNextArr() {
      let nextMonthDateLen = 35 - this.data.preMonthDateLen - this.data.currentMonthDateLen // 下月多余天数
      console.log(" nextMonthDateLen=", nextMonthDateLen);
      let nextMonthDateArr = [] // 定义空数组
      if (nextMonthDateLen > 0) {
        for (let i = 1; i <= nextMonthDateLen; i++) {
          nextMonthDateArr.push({
            month: 'next', // 只是为了增加标识,区分当、上月
            date: i
          })
        }
      } else if (nextMonthDateLen < 0) {
        for (let i = 1; i <= (7 + nextMonthDateLen); i++) {
          nextMonthDateArr.push({
            month: 'next', // 只是为了增加标识,区分当、上月
            date: i
          })
        }
 
      }
      return nextMonthDateArr
    },
    // 整合当月所有日期数据=上月残余+本月+下月多余
    getAllArr() {
      let preArr = this.getPreArr()
      let currentArr = this.getCurrentArr()
      let nextArr = this.getNextArr()
      let allArr = [...preArr, ...currentArr, ...nextArr]
      this.setData({
        allArr
      })
      let sendObj = {
        currentYear: this.data.currentYear,
        currentMonth: this.data.currentMonth,
        currentDate: this.data.selectedDate,
        allArr: this.data.allArr,
      }
      // 向父组件发送数据
      this.triggerEvent('sendObj', sendObj)
 
    },
    // 点击 上月
    gotoPreMonth() {
      let {
        year,
        month
      } = this.preMonth(this.data.currentYear, this.data.currentMonth)
      this.setData({
        currentYear: year,
        currentMonth: month,
      })
      this.getAllArr()
    },
    // 点击 下月
    gotoNextMonth() {
      let {
        year,
        month
      } = this.nextMonth(this.data.currentYear, this.data.currentMonth)
      this.setData({
        currentYear: year,
        currentMonth: month,
      })
      this.getAllArr()
    },
    // 点击日期
    clickDate(e) {
      var date = e.currentTarget.dataset.day;
      var current = e.currentTarget.dataset.current;
      if (current == 0) {
        if (date > 6) {
          // 点击上月日期--去上个月
          var {
            year,
            month
          } = this.preMonth(this.data.currentYear, this.data.currentMonth)
          this.gotoPreMonth()
        } else {
          // 点击下月
          var {
            year,
            month
          } = this.nextMonth(this.data.currentYear, this.data.currentMonth)
          this.gotoNextMonth()
        }
      } else {
        var year = this.data.currentYear;
        var month = this.data.currentMonth;
      }
      this.setData({
        selectedYear: year,
        selectedMonth: month,
        selectedDate: date,
      })
      console.log("当前选择日期", year, "-", month, "-", date);
      console.log(this.data.selectedDate);
      wx.nextTick(() => {
        this.getAllArr()
      })
 
    },
    // 回今天
    gotoToday() {
      this.setData({
        currentYear: this.data.nowYear,
        currentMonth: this.data.nowMonth,
      })
      this.getAllArr()
    }
  }
})

3、打卡及统计

【calendarCard.wxml】

<view class="page-wrapper">
  <top-title toptitle="打卡日历" backImgFlag="true"></top-title>
  <calendar bind:sendObj="getObj" currentPunchCardDate="{{punchCardDateArr}}"></calendar>
  <view class="btn-wrapper">
    <button class="btn" type="primary" disabled="{{ disabledFlag}}" bindtap="punchCard">打 卡</button>
  </view>
  <view class="record-wrapper">
    <view class="title">
      <image class="img" src="{{icon}}"></image> {{name}}打卡统计
    </view>
    <view class="record">
      <view class="record-item">
        <view class="top"><text class="num">{{monthDays}}</text> 天</view>
        <view class="bottom">本月坚持天数</view>
      </view>
      <view class="record-item">
        <view class="top"><text class="num"> {{totalDays}}</text> 天</view>
        <view class="bottom">总共坚持天数</view>
      </view>
    </view>
  </view>
</view>

【calendarCard.wxss】

.page-wrapper {
  background-color: #fff;
  height: 100vh;
}
.page-wrapper .btn-wrapper .btn {
  width: 95vw;
  border-radius: 40rpx;
  height: 80rpx;
  font-size: 30rpx;
  background-color: #27d6f5;
  padding: 20rpx;
}
.page-wrapper .btn-wrapper .btn[disabled] {
  background-color: #e7e5e5;
}
.page-wrapper .record-wrapper {
  padding: 20rpx;
}
.page-wrapper .record-wrapper .title {
  color: #444;
  font-weight: bold;
}
.page-wrapper .record-wrapper .title .img {
  width: 60rpx;
  height: 60rpx;
  position: relative;
  top: 18rpx;
}
.page-wrapper .record-wrapper .record {
  display: flex;
  justify-content: space-around;
  margin-top: 20rpx;
}
.page-wrapper .record-wrapper .record .record-item {
  text-align: center;
  font-size: 24rpx;
  color: #a3a3a3;
}
.page-wrapper .record-wrapper .record .record-item .top {
  height: 80rpx;
  line-height: 80rpx;
  border-bottom: 1px solid #ececec;
  color: #333;
}
.page-wrapper .record-wrapper .record .record-item .top .num {
  font-size: 44rpx;
  font-weight: bold;
  color: #F44336;
}

【calendarCard.js】

// miniprogram/pages/punchCard/calendarCard/calendarCard.js
Page({
 
  /**
   * 页面的初始数据
   */
  data: {
    id: null,
    name: "",
    icon: "",
    disabledFlag: true,
    totalDays:0,
    monthDays:0,
    habitInfo: {},
    currentDate: null,
    currentMonth: null,
    currentYear: null,
    nowYear: new Date().getFullYear(),
    nowMonth: new Date().getMonth(),
    nowDate:new Date().getDate(),
    punchCardDateArr: [] //用于存放当月打卡日期-日
 
  },
  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    console.log(options);
    this.setData({
      id: options.id,
      name: options.name,
      icon: options.icon
    })
    var nowYear = new Date().getFullYear()
    var nowMonth = new Date().getMonth()
    wx.nextTick(() => {
      this.getHabitInfo(nowYear, nowMonth)
    })
  },
  // 获取子组件的数据
  getObj(e) {
    console.log("获取子组件的数据", e);
    this.setData({
      currentDate: e.detail.currentDate,
      currentMonth: e.detail.currentMonth,
      currentYear: e.detail.currentYear,
    })
    this.getHabitInfo(e.detail.currentYear, e.detail.currentMonth - 1)
  },
  // 获取当月的打卡数据
  getHabitInfo(year, month) {
    // 注意month范围 0-11,0代表1月
    const db = wx.cloud.database()
    db.collection('habitList').where({
      _id:this.data.id,
    }).get().then(res => {
      // console.log("从数据库获取数据[res]===", res);
      var dateTimeArr = res.data[0].dateTime
      var dateArr = []
      dateTimeArr.forEach((item) => {
        if (item.getFullYear() == year && item.getMonth() == month) {
          dateArr.push(item.getDate())
        }
      })
      console.log(year, month,this.data.currentDate);
      if (!this.data.currentDate ||(year==this.data.nowYear && month>this.data.nowMonth)||(year==this.data.nowYear && month==this.data.nowMonth &&this.data.currentDate>this.data.nowDate) ) {
        // 打卡按钮禁用的情况(1)页面初始化时,未点击任何日期(2)当前点击的日期在今天之后
        var flag = true
      } else {
        // 打卡按钮禁用的情况 (3)当前日期已打卡
        var flag = dateArr.indexOf(this.data.currentDate) == -1 ? false : true
      }
 
      this.setData({
        habitInfo: res.data[0],
        punchCardDateArr: dateArr,
        disabledFlag: flag,
        totalDays:dateTimeArr.length,
        monthDays:dateArr.length
      })
 
    }).catch(err => {
      console.log(err);
    })
  },
  // 点击打卡按钮-打卡
  punchCard() {
    console.log(this.data.currentYear, this.data.currentMonth - 1, this.data.currentDate);
    var currentTime = new Date(this.data.currentYear, this.data.currentMonth - 1, this.data.currentDate)
    const db = wx.cloud.database()
    db.collection('habitList').doc(this.data.id).update({
      data: {
       dateTime:db.command.push(currentTime)
      },
      success: res => {
        wx.showToast({
          title: '打卡成功',
        })
        this.getHabitInfo(this.data.currentYear, this.data.currentMonth - 1)
      },
      fail: err => {
        wx.showToast({
          icon: 'none',
          title: '新增记录失败'
        })
        console.error('[数据库] [新增记录] 失败:', err)
      }
    })
  }
})

【calendarCard.json】

{
  "usingComponents": {
    "top-title":"../../../components/topTitle/topTitle",
    "calendar":"../components/calendar/calendar"
  }
}

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

(0)

相关推荐

  • 微信小程序实战之打卡时钟的绘制

    目录 一.项目展示 二.首页 三.设置 一.项目展示 这是一款简单实用的小时钟工具 分为工作和休息两种状态 用户可以设置相应的时间 所有的时钟记录都会被保存下来 二.首页 首页由计时器.任务输入框和两个计时按钮组成 <view class="container timer {{isRuning ? 'timer--runing': ''}}"> <view class="timer_main"> <view class="ti

  • 微信小程序实现打卡签到页面

    本文实例为大家分享了微信小程序实现打卡签到页面的具体代码,供大家参考,具体内容如下 效果图如下所示 .wxml <view class='gs_banner'> <view class='gs_continue'> <view>每日坚持签到</view> <view>总共签到:<text>{{continuity}}</text>天</view> </view> </view> <

  • JavaScript实现微信小程序打卡时钟项目实例

    目录 一.项目展示 二.首页 三.设置 一.项目展示 这是一款简单实用的小时钟工具 分为工作和休息两种状态 用户可以设置相应的时间 所有的时钟记录都会被保存下来 二.首页 首页由计时器.任务输入框和两个计时按钮组成 <view class="container timer {{isRuning ? 'timer--runing': ''}}"> <view class="timer_main"> <view class="ti

  • 如何通过Python实现定时打卡小程序

    目录结构: 只需在自己的python项目下随便创建一个文件夹(下图中为:daka),然后将下载的chromedriver.exe.ask_for_leave.py.log.txt(此文件夹为空,保存运行程序时的日志信息,直接在文件夹下创建一个名为log.txt的文件夹即可). chromedriver.exe 此文件是google浏览器的驱动文件,可在下载地址上选择与自己电脑上的google浏览器相同版本的驱动. 如何查看google浏览器版本 第一步:打开Chrome浏览器 第二步:点击右上角

  • 微信小程序实现打卡日历功能

    生活中有各种可以打卡的app,例如背单词打卡什么的,本人觉得很有意思,于是本人在大二时做了一款诚信状打卡的微信小程序,这里讲述一下编写的过程. 先说一下开发环境:用的是微信web开发工具开发的,后台采用了Bmob后台,比较方便. 先展示一下成果: 话不多说,直接上代码,里面也有挺多的注释,以防自己忘记,当然各位如果直接复制过去肯定不能有当前的效果,注意后台数据的交互,不过做一个界面还是没有问题的. Calendar.wxml 页面文件 页面上显示出来的东西,布局上主要是一个年月栏.上一个月和下一

  • 微信小程序实现拍照打卡功能

    本文实例为大家分享了微信小程序实现拍照打卡的具体代码,供大家参考,具体内容如下 由于拍照组件是相当于一个块,用隐藏显示的方法不太好,为了更好的用户交互,选择了在一个新的页面调用相机组件,上传图片并保存打卡数据的方式. 小程序端 签到页面wxml <view class="signBtn" bindtap="signSubmit">   <view>{{signTime}}</view>   <view>打卡签到<

  • python实现自动打卡小程序

    本文实例为大家分享了python实现自动打卡小程序的具体代码,供大家参考,具体内容如下 """ 湖南大学疫情防控每日自动打卡程序v1.0 author: Liu time:2021/3/16 """ from selenium import webdriver from selenium.webdriver.chrome.options import Options from PIL import Image from bs4 import Be

  • 小程序实现日历打卡功能

    本文实例为大家分享了小程序实现日历打卡功能的具体代码,供大家参考,具体内容如下 一.效果图展示 老惯例,先上效果图 二.实现思路 1.日历展示 例如下图中: 2021月7月打卡日历页面,共35个日期数据,上月残余4天+本月31天: 2021月6月打卡日历页面,共35个日期数据,上月残余2天+本月30天+下月残余3天: 2021月5月打卡日历页面,共42个日期数据,上月残余6天+本月31天+下月残余5天. [结论]打卡日历页面存在展示35个或42个日期数据的情况,35个或42个日期数据=当前显示月

  • 微信小程序实现日历功能

    本文实例为大家分享了微信小程序实现日历功能的具体代码,供大家参考,具体内容如下 效果图: 代码: <view class="calendar"> <view class="selectDate"> <view class="goleft iconfont icon-jianzuo" bindtap="prevMonth"></view> <view class="

  • 微信小程序实现日历小功能

    本文实例为大家分享了微信小程序实现日历功能的具体代码,供大家参考,具体内容如下 代码 <!-- 日历 --> <view class="gradient"> <view class="box"> <view class="spaceAroundCenter flex_align_justify_b"> <view class="flex-item"> <view

  • 微信小程序实现日历签到功能

    本文实例为大家分享了微信小程序实现日历签到的具体代码,供大家参考,具体内容如下 wxml: <!--pages/signin/signin.wxml--> <view class="contant">     <!-- 日历年月 -->     <view class='calendar_title layer_center'>         <view class='icon' bindtap='lastMonth'>  

  • 微信小程序实现带刻度尺滑块功能

    摘要: 与自带的slider不同的是,它是通过手势滑动标尺得到取值,而不是通过滑动滑块本身. 效果图 场景 当一屏显示不下,例如年龄体重选择,金额选择等大区间需要的选择器,相比自带的picker要直观一些. 思路: 先画一个scrollView 2 装进canvas lineTo画刻度线段,lineTo+fill画出三角形游标,fillText描绘文本标签 通过bindscroll监听刻度尺触摸事件 渲染取值到页面 基本布局 <scroll-view scroll-x="true"

  • 浅析微信小程序自定义日历组件及flex布局最后一行对齐问题

    最近为我开源的小项目:微信小程序扩展自定义组件库(点击去GitHub) 增加了一个新组件 -- 日历组件. 效果演示: 在编写过程中,因为大家都知道,日历组件是有固定行数和每一行的固定列数的(即使当前方块内没有值),所以结合小程序"数据优先"的特点,最合适的布局方式一定是flex了! 先说一下大致思路(布局上),笔者将整个组件分为两部分:分别是 头部的当前日期(年月)显示,以及左右两侧的切换按钮 当前切换月份的日期显示 头部的布局自不多说:一个 display:flex; 加上 ali

  • 微信小程序中实现车牌输入功能

    目录 前言 背景 大猜想 找规律 结构和样式 组件实现 参数 键盘类型的判断 获取输入内容 组件传参 组件使用 测试 解决键盘类型判断的bug 结束语 组件的代码 使用页面代码 前言 哈哈哈,上新文章啦.好久没有更新啦,今天乘着休息来总结下之前用的到自定义键盘来输入车辆号牌微信组件.下面是效果图,请欣赏: 背景 近期做了一个和车有关的项目,有车肯定就有车牌,我们都知道车牌是有一定规律的,如果简单的给个输入框的话......这里省略一万字哈,从小我的编程老师告诉我不要相信任何用户输入的东西.嗯嗯!

  • 微信小程序 向左滑动删除功能的实现

    微信小程序 向左滑动删除功能的实现 实现效果图: 实现代码: 1.wxml touch-item元素绑定了bindtouchstart.bindtouchmove事件 <view class="container"> <view class="touch-item {{item.isTouchMove ? 'touch-move-active' : ''}}" data-index="{{index}}" bindtouchst

  • 微信小程序实现添加手机联系人功能示例

    本文实例讲述了微信小程序实现添加手机联系人功能.分享给大家供大家参考,具体如下: 1.效果展示   2.关键代码 1)WXML文件 <view bindlongtap="phoneNumTap">{{phoneNum}}</view> 2)JS文件 Page({ data:{ phoneNum:'12345678901'//测试用的号码,并非真实号码 }, // 长按号码响应函数 phoneNumTap:function(){ var that=this; //

随机推荐