我用vs2003开发,求一个好用的日历控件,最好源码。
解决方案 »
- vs2008中文sp1安装MVC的安装包
- .Net用什么方法将毫秒数转换成"天-小时-分钟 秒"这种格式比较好?
- VS2005在调试时所有页面都显示空白
- 用Request.querystring获得的**.aspx?a=云**参数中的“云”中文是乱码,怎么解决?
- 按TAB键获得焦点问题,求大家帮忙!
- 如何利用ASP.NET开发提取用户表单提交的请求参数.(AJAX基础教程中的一个问题)
- 再放100分,找一网通用户帮我测一下网站速度。
- 救命啊!关于水晶报表CrystalReportViewer无法加入WEBFORM1的问题(生死关天)谢谢!
- 过年了,发个修改过的FCKEditor,给大家做新年礼物
- 求助!!
- .NET网站相对路径的问题
- 如何连接access database ?
需要的话再给你贴代码
my97
万年历
//调用:onFocus="showCalender(this,'yyyy-mm-dd',1980,2029)"
//My97Date控件中的 < 月 年 >,单击 <或>没有前进可后退,提示网页有错误,我想不用此两个按钮,js文件我不会,请问如何修改js文件,去掉这两个“ < >”
js文件如下: /*----------------------------------------------------------------------------|
| Subject: Simple Datepicker
| Version: 1.0
| Author: Anonymous
| Revisor Sunarrow
| Created: 2008-9-26
| LastModified: 2008-9-26
| Download: http://code.google.com/p/cwin/downloads/list
\-----------------------------------------------------------------------------*/
var _c_allMonth=[31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
var _c_allNameOfWeekDays=["一","二", "三", "四", "五", "六", "日"];
var _c_allNameOfMonths=["一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月"];
var _c_dateFormat = "yyyy-mm-dd";
var _c_newDate=new Date();
var _c_yearZero=_c_newDate.getFullYear();
var _c_monthZero=_c_newDate.getMonth();
var _c_day=_c_newDate.getDate();
var _c_currentDay=0, currentDayZero=0;
var _c_month=_c_monthZero, year=_c_yearZero;
var _c_yearMin=1970, _c_yearMax=2020;
var _c_target='';
var _c_hoverEle=false; document.write(" <style type=\"text/css\">#basis {display:inline;position:relative;}#calender {position:absolute;top:30px;left:0;width:220px;background-color:#fff;border:3px solid #ccc;padding:10px;z-index:10;}#control {text-align:center;margin:0 0 5px 0;}#control select {font-family:\"Lucida sans unicode\", sans-serif;font-size:11px;margin:0 5px;vertical-align:middle;}#calender .controlPlus {padding:0 5px;text-decoration:none;color:#333;}#calender table {empty-cells: show;width:100%;font-size:11px;table-layout:fixed;}#calender .weekdays td{text-align:right;padding:1px 5px 1px 1px;color:#333;}#calender .week td {text-align:right;cursor:pointer;border:1px solid #fff;padding:1px 4px 1px 0;}#calender .week .today { background-color:#ccf;border-color:#ccf;}#calender .week .holiday {font-weight: bold;}#calender .week .hoverEle {border-color:#666;background-color:#99f;color:#000;} </style>"); function setCalenderTarget(e){
if(e) return e.target;
if(event) return event.srcElement;
return null;
}
function newCalenderElement(type, attrs, content, toNode) {
var ele=document.createElement(type);
if(attrs) {
for(var i=0; i <attrs.length; i++) {
eval('ele.'+attrs[i][0]+(attrs[i][2] ? '=\u0027' :'=')+attrs[i][1]+(attrs[i][2] ? '\u0027' :''));
}
}
if(content) ele.appendChild(document.createTextNode(content));
if(toNode) toNode.appendChild(ele);
return ele;
}
function setCalenderMonth(ele){_c_month=parseInt(ele.value);calender()}
function setCalenderYear(ele){year=parseInt(ele.value);calender()}
function setCalenderValue(ele) {
if(ele.parentNode.className=='week' && ele.firstChild){
var dayOut=ele.firstChild.nodeValue;
if(dayOut < 10) dayOut='0'+dayOut;
var monthOut=_c_month+1;
if(monthOut < 10) monthOut='0'+monthOut;
var datestring = _c_dateFormat;
datestring = datestring.replace("yyyy",year);
datestring = datestring.replace("mm",monthOut);
datestring = datestring.replace("dd",dayOut);
_c_target.value = datestring;
removeCalender();
}
}
function removeCalender() {
var parentEle=document.getElementById("calender");
while(parentEle.firstChild) parentEle.removeChild(parentEle.firstChild);
document.getElementById('basis').parentNode.removeChild(document.getElementById('basis'));
}
function calender() {
var parentEle=document.getElementById("calender");
parentEle.onmouseover=function(e) {
var ele=setCalenderTarget(e);
if(ele.parentNode.className=='week' && ele.firstChild && ele!=_c_hoverEle) {
if(_c_hoverEle) _c_hoverEle.className=_c_hoverEle.className.replace(/hoverEle ?/,'');
_c_hoverEle=ele;
ele.className='_c_hoverEle '+ele.className;
} else {
if(_c_hoverEle) {
_c_hoverEle.className=_c_hoverEle.className.replace(/hoverEle ?/,'');
_c_hoverEle=false;
}
}
}
while(parentEle.firstChild) parentEle.removeChild(parentEle.firstChild);
function check(){
if(year%4==0&&(year%100!=0||year%400==0))_c_allMonth[1]=29;
else _c_allMonth[1]=28;
}
function addClass (name) { if(!currentClass){currentClass=name} else {currentClass+=' '+name} };
if(_c_month < 0){_c_month+=12; year-=1}
if(_c_month > 11){_c_month-=12; year+=1}
if(year==_c_yearMax-1) _c_yearMax+=1;
if(year==_c_yearMin) _c_yearMin-=1;
check();
var control=newCalenderElement('p',[['id','control',1]],false,parentEle);
var controlPlus=newCalenderElement('a', [['href','javascript:month--;calender()',1],['className','controlPlus',1]], ' <', control);
var select=newCalenderElement('select', [['onchange',function(){setCalenderMonth(this)}]], false, control);
for(var i=0; i <_c_allNameOfMonths.length; i++) newCalenderElement('option', [['value',i,1]], _c_allNameOfMonths[i], select);
select.selectedIndex=_c_month;
select=newCalenderElement('select', [['onchange',function(){setCalenderYear(this)}]], false, control);
for(var i=_c_yearMin; i <_c_yearMax; i++) newCalenderElement('option', [['value',i,1]], i, select);
select.selectedIndex=year-_c_yearMin;
controlPlus=newCalenderElement('a', [['href','javascript:month++;calender()',1],['className','controlPlus',1]], '>', control);
check();
_c_currentDay=1-new Date(year,_c_month,1).getDay();
if(_c_currentDay > 0) _c_currentDay-=7;
currentDayZero=_c_currentDay;
var newMonth=newCalenderElement('table',[['cellSpacing',0,1],['onclick',function(e){setCalenderValue(setCalenderTarget(e))}]], false, parentEle);
var newMonthBody=newCalenderElement('tbody', false, false, newMonth);
var tr=newCalenderElement('tr', [['className','head',1]], false, newMonthBody);
tr=newCalenderElement('tr', [['className','weekdays',1]], false, newMonthBody);
for(i=0;i <7;i++) td=newCalenderElement('td', false, _c_allNameOfWeekDays[i], tr);
tr=newCalenderElement('tr', [['className','week',1]], false, newMonthBody);
for(i=0; i <_c_allMonth[_c_month]-currentDayZero; i++){
var currentClass=false;
_c_currentDay++;
if(_c_currentDay==_c_day && _c_month==_c_monthZero && year==_c_yearZero) addClass ('today');
if(_c_currentDay <= 0 ) {
if(currentDayZero!=-7) td=newCalenderElement('td', false, false, tr);
}
else {
if((_c_currentDay-currentDayZero)%7==0) addClass ('holiday');
td=newCalenderElement('td', (!currentClass ? false : [['className',currentClass,1]] ), _c_currentDay, tr);
if((_c_currentDay-currentDayZero)%7==0) tr=newCalenderElement('tr', [['className','week',1]], false, newMonthBody);
}
if(i==_c_allMonth[_c_month]-currentDayZero-1){
i++;
while(i%7!=0){i++;td=newCalenderElement('td', false, false, tr)};
}
}
}
/**
* show date picker
* @param e input element
* @param df dateformat :optional parameters
* @param min min year : optional parameters
* @param max max year : optional parameters
*/
function showCalender(e,df,min,max) {
if(df != undefined && df != ''){
_c_dateFormat = df;
}
if(min != undefined && max != undefined){
_c_yearMin = min;
_c_yearMax = max;
}
if(document.getElementById('basis')) { removeCalender() }
else {
_c_target=e;
var basis=e.parentNode.insertBefore(document.createElement('div'),e);
basis.id='basis';
newCalenderElement('div', [['id','calender',1]], false, basis);
calender();
}
}