一、问题:

  在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日期控件遇到的问题的更多相关文章

  1. 利用js日期控件重构WEB功能

    开发需求:网页中的日期部门(注册页面和查询条件)都用js日期控件重写 页面一:更新员工页面 empUpdate.jsp 中增加 onfocus 事件 入职日期:<input id="h ...

  2. JSP JS 日期控件的下载、使用及注意事项

    网上流行的时间日期控件比较多,个人觉得My97DatePicker的日期控件不错,值得推荐. 具体的使用过程如下: 1.下载My97DatePicker.rar或 My97DatePickerBeta ...

  3. js日期控件demo

    最近在钻研前端,写了个日期控件,内涵代码注释,希望能帮助到大家~ 1.html代码 <!DOCTYPE html> <html xmlns="http://www.w3.o ...

  4. js 日期控件 可以显示为和历

    日期控件的js <!-- /** * Calendar * @param beginYear 1990 * @param endYear 2010 * @param language 0(zh_ ...

  5. js日期控件

    My97日期控件 官方网站 My97 Datepicker Home   http://www.my97.net/

  6. layDate1.0正式公布,您一直在寻找的的js日期控件

    你是时候换一款日期控件了,而layDate很愿意和您成为工作伙伴.她正致力于成为全球最高大上的web日期支撑,为国内外全部从事web应用开发的同仁提供力所能及的动力.她基于原生JavaScript精心 ...

  7. 推荐几款开源的js日期控件

    做为一个正规的网站,经常需要一些日期或时间的筛选,所以我们今天就推荐二十多款javascript的js日期/时间筛选插件.个个经典,绝对有你需要的. My97DatePicker ,国人开发的一款js ...

  8. js 日期控件laydate使用

    官网  http://sentsin.com/layui/laydate/ 1. 下载官网上的压缩包,解压后只需要复制laydate 文件夹到你的项目中; 2. 在页面引入  <script t ...

  9. WebFrom 的js日期控件

    1.WdatePicker.js /* * My97 DatePicker 4.7 Release * License: http://www.my97.net/dp/license.asp */ v ...

随机推荐

  1. GCD vs NSOperation

    GCD is a lightweight way to represent units of work that are going to be executed concurrently. You ...

  2. Linux文件系统知识记录——ext2描述

    最近完成了一个编程作业,大致功能是给定一个文件名,给出该文件所在目录和其本身所占用的簇号等信息.笔者选用了Linux的ext系列文件系统作为实验对象,通过实验对ext2文件系统的存储和索引有了一个较为 ...

  3. PhoneGap检测设备网络连接情况

    一.网络连接状态列表 Phonegap 网络连接通过 navigator.network.connection.type 来获取,一般有一下几种状态 1. Connection.UNKNOWN     ...

  4. Python version 3.6 required, which was not found in the registry错误解决

    问题: 安装pywin32出现Python version 3.6 required, which was not found in the registry错误解决 解决: 建立一个文件 regis ...

  5. [Java123] Java中的System.exit

    参考:http://www.cnblogs.com/xwdreamer/archive/2011/01/07/2297045.html System.exit(int  status) 方法 java ...

  6. EF和linq to sql 关系

    LINQ to SQL 允许你用任何类来代表数据库中的数据.表.同样的,EF也允许你用任何类来代表苏据库中的数据.表. 所不同的的地方是Linq to sql 用这些被修饰过的类直接同数据库打交道,存 ...

  7. Fedora Server 上配置 MariaDb 集群

    下载与安装 MariaDB Galera Cluster 10.1之前的版本安装,输入以下命令进行安装: sudo dnf install mariadb-galera-server 如果电脑上还没安 ...

  8. ApiCloud模块链接

    城市选择器 页面左右滑动 识别信用卡 图像coverFlow  输入框  图片浏览器  百度地图                                                     ...

  9. Dubbo实践(七)扩展点

    与JDK的SPI机制类似,Dubbo也在META-INF路径下定义了多种扩展接口.只是JDK SPI机制是Java后台帮你实现读取文件并对接具体的实现类,而Dubbo是自己去读文件. 扩展点配置 扩展 ...

  10. Ubuntu16.04配置单机版Zookeeper和Kafka

    1. 配置zookeeper单机模式 选择的是zookeeper-3.4.10版本,官网下载链接:http://mirrors.hust.edu.cn/apache/zookeeper/stable/ ...