js日期控件遇到的问题
一、问题:
在web项目里有很多时候需要使用日期控件来完成相关的功能,但是日期控件的日期格式又和我们的需求不符
那么,就需要我们来自定义日期的格式完成需求
二、解决:
1、取月末:
(1)强制取值:
//判断每个月最后一天
function lastDay(cYear,cMouth){
var year;
var mouth;
if (cYear != "" && cMouth!="") {
year=cYear;
mouth=cMouth;
} else {
var date =new Date();
year=date.getFullYear();//获取年份
mouth=date.getMonth() + 1;
}
var days;
if (mouth==2) {
//当月份为二月时,根据闰年还是非闰年判断天数
if (year % 400 == 0 || year % 4 == 0 && year % 100 != 0 ) {
days=29;
}else{
days=28;
};
}else if (mouth == 1 || mouth == 3 || mouth == 5 || mouth == 7 || mouth == 8 || mouth == 10 || mouth == 12) {
//月份为:1,3,5,7,8,10,12 时,为大月.则天数为31
days= 31;
}else {
//其他月份,天数为:30.
days= 30;
}
return days;
};(2)使用js日期函数来求:原理涉及到js日期函数的顺序加载问题,先加一,后减一
function getPreMonthLastDay() { // debugger;
var date = new Date();
var year = date.getFullYear().toString();
var month = (date.getMonth()).toString();
var temp = new Date(year,month,0);
day = (temp.getDate()).toString(); if(month.length == 1) month = "0" + month;
if(day.length == 1) day = "0" + day; return year + "-" + month + "-" + day; }2、日期位数不定:(区分年报,月报,日报)
//初始化日期
var firstLoad = 0;
function initReportDateFun(rtypeV){
$("#reportDate").datebox({
width:150,
required:false,
onSelect:function(date){
//var date = $("#reportDate").datebox("getValue");
var selectValue = $('#reportFileType').combobox("getValue");
var tvalue = "";
if(selectValue == "Y"){
tvalue = fmtReportDate(date,"yyyy");
}else if(selectValue == "M"){
tvalue = fmtReportDate(date,"yyyy-MM");
}else{
tvalue = fmtReportDate(date,"yyyy-MM-dd");
}
$("#reportDate").datebox("setText",tvalue);
},
parser:function(date){
var t = Date.parse(date);
if (!isNaN(t)){
return new Date(t);
} else {
return new Date();
}
}
}); // var selectValue = $('#reportFileType').combobox("getValue");
if(rtypeV == "Y"){
$("#reportDate").datebox("setText",fmtReportDate(new Date(),"yyyy"));
}else if(rtypeV == "M"){
$("#reportDate").datebox("setText",fmtReportDate(new Date(),"yyyy-MM"));
}else{
if(firstLoad>0){
$("#reportDate").datebox("setText",fmtReportDate(new Date(),"yyyy-MM-dd"));
}else{
$("#reportDate").datebox("setText",getPreMonthLastDay());
firstLoad ++;
}
}
/*if(firstLoad==0){
clearVal();
/!*var curr_time = new Date();
var strDate = curr_time.getFullYear()+"-";
strDate += curr_time.getMonth()+1+"-";
strDate += curr_time.getDate();
$("#reportDate").datebox("setValue", strDate);
initTxtOrg();*!/
firstLoad++;
}else{*/
initTxtOrg();
init_report_detail_tab();
initStatisTable();
//}
}出现的问题:
之前没有加【parser】函数,会出现一个问题,选择5月份的日期后,日期框还是保留【今天】,日期和框显示的数据不一致
可能是由于处理时间的时候会把数据作文文本显示,但是控件并不能解析这个字符串而让面板和显示的字符串日期保持一致
使用【parser】函数后,每次加载完成,会把字符串解析成一个日期函数以供控件加载初始化数据
js日期控件遇到的问题的更多相关文章
- 利用js日期控件重构WEB功能
开发需求:网页中的日期部门(注册页面和查询条件)都用js日期控件重写 页面一:更新员工页面 empUpdate.jsp 中增加 onfocus 事件 入职日期:<input id="h ...
- JSP JS 日期控件的下载、使用及注意事项
网上流行的时间日期控件比较多,个人觉得My97DatePicker的日期控件不错,值得推荐. 具体的使用过程如下: 1.下载My97DatePicker.rar或 My97DatePickerBeta ...
- js日期控件demo
最近在钻研前端,写了个日期控件,内涵代码注释,希望能帮助到大家~ 1.html代码 <!DOCTYPE html> <html xmlns="http://www.w3.o ...
- js 日期控件 可以显示为和历
日期控件的js <!-- /** * Calendar * @param beginYear 1990 * @param endYear 2010 * @param language 0(zh_ ...
- js日期控件
My97日期控件 官方网站 My97 Datepicker Home http://www.my97.net/
- layDate1.0正式公布,您一直在寻找的的js日期控件
你是时候换一款日期控件了,而layDate很愿意和您成为工作伙伴.她正致力于成为全球最高大上的web日期支撑,为国内外全部从事web应用开发的同仁提供力所能及的动力.她基于原生JavaScript精心 ...
- 推荐几款开源的js日期控件
做为一个正规的网站,经常需要一些日期或时间的筛选,所以我们今天就推荐二十多款javascript的js日期/时间筛选插件.个个经典,绝对有你需要的. My97DatePicker ,国人开发的一款js ...
- js 日期控件laydate使用
官网 http://sentsin.com/layui/laydate/ 1. 下载官网上的压缩包,解压后只需要复制laydate 文件夹到你的项目中; 2. 在页面引入 <script t ...
- WebFrom 的js日期控件
1.WdatePicker.js /* * My97 DatePicker 4.7 Release * License: http://www.my97.net/dp/license.asp */ v ...
随机推荐
- Vim常用命令记录
(本文仅记录了Vim常用的按键功能和操作,用于备忘和查阅.若为Vim小白,建议先通过列出的参考资源获得对Vim更全面的了解.Vi 是几乎所有Linux发行版都支持的文字编辑工具,也是许多Linux下工 ...
- 25、springboot与缓存整合Redis
默认使用ConcurrentMapCacheManager 将数据保存在下面的Map中 docker: 安装Redis: 查看官方文档: 添加约束 <dependency> <gro ...
- BurpSuite Intruder 4种攻击模式
BurpSuite intruder attack-type 4种爆破模式 Sniper 单参数爆破,多参数时同一个字典按顺序替换各参数,总之初始值有一个参数不变 Battering ram 多参数同 ...
- 一般处理程序中,获取session
注意了: 1.要在一般处理程序中获取其他页面的session值,需要引用名空间: using System.Web.SessionState; 2.然后继承一个接口:IRequiresSessionS ...
- Redis(三)内存模型
本文转载自编程迷思,原文链接 深入学习Redis(1):Redis内存模型 前言 Redis是目前最火爆的内存数据库之一,通过在内存中读写数据,大大提高了读写速度,可以说Redis是实现网站高并发不可 ...
- Mac 下 SVN 的使用
在Windows环境中,我们一般使用TortoiseSVN来搭建svn环境.在Mac环境下,由于Mac自带了svn的服务器端和客户端功能,所以我们可以在不装任何第三方软件的前提下使用svn功能,不过还 ...
- CC2640R2F&TI-RTOS 拿到 TI CC2640R2F 开发板 第三件事就是使用 TI-RTOS 创建 一个任务 和 使用 信号量 超时来闪烁 LED灯
/* * data_process.c * * Created on: 2018年7月5日 * Author: admin */ #include <ti/sysbios/knl/Task.h& ...
- redefinition of class解决
垃圾玩意我在这儿翻车了. 编译器:Code::Block(懒得用VS,而且又太大了,CB小,而且也就一个控制台程序) Note to myself: 写完一个class的文件定义,编译,通过之后: 1 ...
- es6 入坑笔记(五)
Symbol 主要用做key或私有变量,Symbol是唯一的不可重复的,也是一个单独的数据类型 定义形式: let demo=Symbol("aaaa"); 1.Symbol不能使 ...
- Linux网卡配置文件 参数详解
之所以弄这玩意儿是图个清晰方便,最近这段时间弄了好十来次虚拟机网络了ubuntu,centos,rhat7各种折腾,其实把网上各种命令行下的攻略折腾最后关键无非都是对/etc/sysconfig/ne ...