首页 > 编程知识 正文

js日期选择器php(jq日期选择器)

时间:2023-12-07 13:39:21 阅读:312847 作者:MVDQ

本文目录一览:

  • 1、js 日期选择器 如何选取时间范围
  • 2、js日期选择打开相关链接 选择2013-04-05 打开http://www.baidu.com/2013-o4/05/d.html
  • 3、js时间选择插件哪个最好用 知乎
  • 4、PHP怎样添加JS日历控件
  • 5、如何使用PHP制作一个日期的下拉菜单啊?求PHP大神赐教啊?

js 日期选择器 如何选取时间范围

不是特别明白问的问题,什么叫选取时候范围:

一、年份的范围: 在JS里面 Year 应该有一般是 1970-2020 你可以自己改

二、时间格式:如只要日期,或者日期+时间:这个要看JS里面有没有相应的函数:如: setYear()一般日期 setTime() 时间 或者:setYearTime() 你可以直接查找 set...开始的函数

js日期选择打开相关链接 选择2013-04-05 打开http://www.baidu.com/2013-o4/05/d.html

html

head

titleJS日期选择器/title

script type="text/javascript"

function HS_DateAdd(interval,number,date){

number = parseInt(number);

if (typeof(date)=="string"){var date = new Date(date.split("-")[0],date.split("-")[1],date.split("-")[2])}

if (typeof(date)=="object"){var date = date}

switch(interval){

case "y":return new Date(date.getFullYear()+number,date.getMonth(),date.getDate()); break;

case "m":return new Date(date.getFullYear(),date.getMonth()+number,checkDate(date.getFullYear(),date.getMonth()+number,date.getDate())); break;

case "d":return new Date(date.getFullYear(),date.getMonth(),date.getDate()+number); break;

case "w":return new Date(date.getFullYear(),date.getMonth(),7*number+date.getDate()); break;

}

}

function checkDate(year,month,date){

var enddate = ["31","28","31","30","31","30","31","31","30","31","30","31"];

var returnDate = "";

if (year%4==0){enddate[1]="29"}

if (dateenddate[month]){returnDate = enddate[month]}else{returnDate = date}

return returnDate;

}

function WeekDay(date){

var theDate;

if (typeof(date)=="string"){theDate = new Date(date.split("-")[0],date.split("-")[1],date.split("-")[2]);}

if (typeof(date)=="object"){theDate = date}

return theDate.getDay();

}

function HS_calender(){

var lis = "";

var style = "";

style +="style type='text/css'";

style +=".calender { width:170px; height:auto; font-size:12px; margin-right:14px; background:url(calenderbg.gif) no-repeat right center #fff; border:1px solid #397EAE; padding:1px}";

style +=".calender ul {list-style-type:none; margin:0; padding:0;}";

style +=".calender .day { background-color:#EDF5FF; height:20px;}";

style +=".calender .day li,.calender .date li{ float:left; width:14%; height:20px; line-height:20px; text-align:center}";

style +=".calender li a { text-decoration:none; font-family:Tahoma; font-size:11px; color:#333}";

style +=".calender li a:hover { color:#f30; text-decoration:underline}";

style +=".calender li a.hasArticle {font-weight:bold; color:#f60 !important}";

style +=".lastMonthDate, .nextMonthDate {color:#bbb;font-size:11px}";

style +=".selectThisYear a, .selectThisMonth a{text-decoration:none; margin:0 2px; color:#000; font-weight:bold}";

style +=".calender .LastMonth, .calender .NextMonth{ text-decoration:none; color:#000; font-size:18px; font-weight:bold; line-height:16px;}";

style +=".calender .LastMonth { float:left;}";

style +=".calender .NextMonth { float:right;}";

style +=".calenderBody {clear:both}";

style +=".calenderTitle {text-align:center;height:20px; line-height:20px; clear:both}";

style +=".today { background-color:#ffffaa;border:1px solid #f60; padding:2px}";

style +=".today a { color:#f30; }";

style +=".calenderBottom {clear:both; border-top:1px solid #ddd; padding: 3px 0; text-align:left}";

style +=".calenderBottom a {text-decoration:none; margin:2px !important; font-weight:bold; color:#000}";

style +=".calenderBottom a.closeCalender{float:right}";

style +=".closeCalenderBox {float:right; border:1px solid #000; background:#fff; font-size:9px; width:11px; height:11px; line-height:11px; text-align:center;overflow:hidden; font-weight:normal !important}";

style +="/style";

var now;

if (typeof(arguments[0])=="string"){

selectDate = arguments[0].split("-");

var year = selectDate[0];

var month = parseInt(selectDate[1])-1+"";

var date = selectDate[2];

now = new Date(year,month,date);

}else if (typeof(arguments[0])=="object"){

now = arguments[0];

}

var lastMonthEndDate = HS_DateAdd("d","-1",now.getFullYear()+"-"+now.getMonth()+"-01").getDate();

var lastMonthDate = WeekDay(now.getFullYear()+"-"+now.getMonth()+"-01");

var thisMonthLastDate = HS_DateAdd("d","-1",now.getFullYear()+"-"+(parseInt(now.getMonth())+1).toString()+"-01");

var thisMonthEndDate = thisMonthLastDate.getDate();

var thisMonthEndDay = thisMonthLastDate.getDay();

var todayObj = new Date();

today = todayObj.getFullYear()+"-"+todayObj.getMonth()+"-"+todayObj.getDate();

for (i=0; ilastMonthDate; i++){ // Last Month's Date

lis = "li class='lastMonthDate'"+lastMonthEndDate+"/li" + lis;

lastMonthEndDate--;

}

for (i=1; i=thisMonthEndDate; i++){ // Current Month's Date

if(today == now.getFullYear()+"-"+now.getMonth()+"-"+i){

var todayString = now.getFullYear()+"-"+(parseInt(now.getMonth())+1).toString()+"-"+i;

lis += "lia href=javascript:void(0) class='today' onclick='_selectThisDay(this)' title='"+now.getFullYear()+"-"+(parseInt(now.getMonth())+1)+"-"+i+"'"+i+"/a/li";

}else{

lis += "lia href=javascript:void(0) onclick='_selectThisDay(this)' title='"+now.getFullYear()+"-"+(parseInt(now.getMonth())+1)+"-"+i+"'"+i+"/a/li";

}

}

var j=1;

for (i=thisMonthEndDay; i6; i++){ // Next Month's Date

lis += "li class='nextMonthDate'"+j+"/li";

j++;

}

lis += style;

var CalenderTitle = "a href='javascript:void(0)' class='NextMonth' onclick=HS_calender(HS_DateAdd('m',1,'"+now.getFullYear()+"-"+now.getMonth()+"-"+now.getDate()+"'),this) title='Next Month'»/a";

CalenderTitle += "a href='javascript:void(0)' class='LastMonth' onclick=HS_calender(HS_DateAdd('m',-1,'"+now.getFullYear()+"-"+now.getMonth()+"-"+now.getDate()+"'),this) title='Previous Month'«/a";

CalenderTitle += "span class='selectThisYear'a href='javascript:void(0)' onclick='CalenderselectYear(this)' title='Click here to select other year' "+now.getFullYear()+"/a/span年span class='selectThisMonth'a href='javascript:void(0)' onclick='CalenderselectMonth(this)' title='Click here to select other month'"+(parseInt(now.getMonth())+1).toString()+"/a/span月";

if (arguments.length1){

arguments[1].parentNode.parentNode.getElementsByTagName("ul")[1].innerHTML = lis;

arguments[1].parentNode.innerHTML = CalenderTitle;

}else{

var CalenderBox = style+"div class='calender'div class='calenderTitle'"+CalenderTitle+"/divdiv class='calenderBody'ul class='day'li日/lili一/lili二/lili三/lili四/lili五/lili六/li/ulul class='date' id='thisMonthDate'"+lis+"/ul/divdiv class='calenderBottom'a href='javascript:void(0)' class='closeCalender' onclick='closeCalender(this)'×/aspanspana href=javascript:void(0) onclick='_selectThisDay(this)' title='"+todayString+"'Today/a/span/span/div/div";

return CalenderBox;

}

}

function _selectThisDay(d){

var boxObj = d.parentNode.parentNode.parentNode.parentNode.parentNode;

var arr= d.title.split(/-/);

if(arr[1].length2)arr[1]="0"+arr[1];

if(arr[2].length2)arr[2]="0"+arr[2];

d.title = arr[0]+"-"+arr[1]+"-"+arr[2];

boxObj.targetObj.value = d.title;

boxObj.parentNode.removeChild(boxObj);

var selDay= new Date(arr[0],arr[1]-1,arr[2]);

var lowLim = new Date(2013,4-1,1);

var todayObj = new Date();

//alert(selDay);alert(lowLim);alert(todayObj);

if(selDaylowLim || selDay todayObj)return;

var gogogo;

// gogogo= document.location.protocol+"//"+document.location.host+":"+document.location.port+"/"+arr[0]+"-"+arr[1]+"/"+arr[2]+"/d.htm";

gogogo = ""+"/"+arr[0]+"-"+arr[1]+"/"+arr[2]+"/d.htm";

//alert(gogogo);

//if(window.confirm("do you want go there("+gogogo+")"))

document.location.href = gogogo;

}

function closeCalender(d){

var boxObj = d.parentNode.parentNode.parentNode;

boxObj.parentNode.removeChild(boxObj);

}

function CalenderselectYear(obj){

var opt = "";

var thisYear = obj.innerHTML;

for (i=1970; i=2020; i++){

if (i==thisYear){

opt += "option value="+i+" selected"+i+"/option";

}else{

opt += "option value="+i+""+i+"/option";

}

}

opt = "select onblur='selectThisYear(this)' onchange='selectThisYear(this)' style='font-size:11px'"+opt+"/select";

obj.parentNode.innerHTML = opt;

}

function selectThisYear(obj){

HS_calender(obj.value+"-"+obj.parentNode.parentNode.getElementsByTagName("span")[1].getElementsByTagName("a")[0].innerHTML+"-1",obj.parentNode);

}

function CalenderselectMonth(obj){

var opt = "";

var thisMonth = obj.innerHTML;

for (i=1; i=12; i++){

if (i==thisMonth){

opt += "option value="+i+" selected"+i+"/option";

}else{

opt += "option value="+i+""+i+"/option";

}

}

opt = "select onblur='selectThisMonth(this)' onchange='selectThisMonth(this)' style='font-size:11px'"+opt+"/select";

obj.parentNode.innerHTML = opt;

}

function selectThisMonth(obj){

HS_calender(obj.parentNode.parentNode.getElementsByTagName("span")[0].getElementsByTagName("a")[0].innerHTML+"-"+obj.value+"-1",obj.parentNode);

}

function HS_setDate(inputObj){

var calenderObj = document.createElement("span");

calenderObj.innerHTML = HS_calender(new Date());

calenderObj.style.position = "absolute";

calenderObj.targetObj = inputObj;

inputObj.parentNode.insertBefore(calenderObj,inputObj.nextSibling);

}

/script

style

body {font-size:12px}

td {text-align:center}

h1 {font-size:26px;}

h4 {font-size:16px;}

em {color:#999; margin:0 10px; font-size:11px; display:block}

/style

/head

body

table border="1" width="400" height="150"

tr

td这是示例文字文本input type="text" style="width:70px" onfocus="HS_setDate(this)"文本/td

/tr

/table

/body

/html

以上代码从日期控件中修改。

=============

以上仅供学习参考,日期控件版权属于原作者。

js时间选择插件哪个最好用 知乎

一下好一款laydate.js日期时间选择插件,具有一定的参考价值,希望可以帮到你

日期时间选择插件laydate.js:

效果图:

1. 引入JS。 

script type="text/javascript" src="js/laydate.js"/script

2. 根据需要做相应的配置。详情参看官网

script

 laydate({

  elem: '#seldate', //目标元素。由于laydate.js封装了一个轻量级的选择器引擎,因此elem还允许你传入class、tag但必须按照这种方式 '#id .class'

  event: 'focus', //响应事件。如果没有传入event,则按照默认的click

  format: 'YYYY/MM/DD hh:mm:ss', // 分隔符可以任意定义,该例子表示只显示年月

  festival: true, //显示节日

  istime: true, //显示时间选项

  choose: function(datas){ //选择日期完毕的回调

   alert('得到:'+datas);

  }

 });

/script

实例源码:

!DOCTYPE html 

html 

head 

 meta charset="utf-8" 

 meta http-equiv="X-UA-Compatible" content="IE=edge" 

 meta name="viewport" content="width=device-width, initial-scale=1" 

 !-- 

 link href="favicon.ico" rel="shortcut icon" type="image/x-icon" / 

 link href="favicon.ico" rel="Bookmark" type="image/x-icon" / 

 --

 meta name="Generator" content="EditPlus®" 

 meta name="Author" content="" 

 meta name="Keywords" content="" 

 meta name="Description" content="" 

 titlelayDate日期时间选择插件/title 

 link href="" rel="stylesheet" / 

 script type="text/javascript" src="js/laydate.js"/script 

/head 

body 

 form method="post" action="" 

 Way1, 

  请选择日期:input type="text" name="date" onclick="laydate()" / 

  hr / 

 Way2, 

  input type="text" name="date" id='seldate' class="laydate-icon" /hr / 

  script 

   laydate({ 

    elem: '#seldate', //目标元素。由于laydate.js封装了一个轻量级的选择器引擎,因此elem还允许你传入class、tag但必须按照这种方式 '#id .class' 

    event: 'focus', //响应事件。如果没有传入event,则按照默认的click 

    format: 'YYYY/MM/DD hh:mm:ss', // 分隔符可以任意定义,该例子表示只显示年月 

    festival: true, //显示节日 

    istime: true, //显示时间选项 

    choose: function(datas){ //选择日期完毕的回调 

     alert('得到:'+datas); 

    } 

   }); 

  /script 

 Way3, 

  input id="seldate1" 

  span class="laydate-icon" onclick="laydate({elem:'#seldate1'});"/span 

 /form 

/body 

/html

PHP怎样添加JS日历控件

日期插件的包为:mydate.js。

1:首先将日期插件的包引入到页面中

script language="JavaScript" src="../Inc/Js/mydate.js"/script

2:设置鼠标点击事件,当鼠标点击获得焦点的时候,触发事件,调用方法

input type="text" name="starttime" onfocus="MyCalendar.SetDate(this)" value="?php echo $rq;?"

input type="text" name="endtime" onfocus="MyCalendar.SetDate(this)" value="?php echo $rq;?"

3:完整页面代码

?php

  date_default_timezone_set("PRC");

  $nowtime = time();

  $rq = date("Y-m-d",$nowtime);

?

html

head

meta http-equiv="Content-Type" content="text/html; charset=gb2312" /

meta name="generator" content="FFKJ.Net" /

link rev="MADE" href="mailto:FFKJ@FFKJ.Net"

title在线--后台/title

link rel="stylesheet" type="text/css" href="../Skins/Admin_Style.Css" /

script language="JavaScript" src="../Inc/Js/mydate.js"/script

/head

body

开始时间:input type="text" name="starttime" onfocus="MyCalendar.SetDate(this)" value="?php echo $rq;?"

结束时间:input type="text" name="endtime" onfocus="MyCalendar.SetDate(this)" value="?php echo $rq;?"

/body

/html

如何使用PHP制作一个日期的下拉菜单啊?求PHP大神赐教啊?

php是服务器端语言,不管你是下拉框方式的日历还是使用日历插件都是html和js的事情,和php无关。

你可以直接搜索3级联动日历选择代码或者直接用jQuery的日历插件,非常方便,官网有示例。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。