Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 29.07.2011, 04:33
Новичок на форуме
Отправить личное сообщение для mrflow Посмотреть профиль Найти все сообщения от mrflow
 
Регистрация: 29.07.2011
Сообщений: 8

Форма + календарь на яве (смещается)
У меня есть скрипт "всплывающего" календаря. Он выводится при нажатии на <input> и должен быть размещён относительно этого самого <input>. В стиле таблицы прописано position:relative;
Это работало до какого-то времени. Но потом я немного редактировал код + сохранил его в utf-8. Но разве кодировка может что-то поменять?
Ниже код страницы и после неё(во втором сообщении, так как в одном всё не влезает) код календаря + скриншот того, что происходит.

<html>
<head>

<style type="text/css">
.pol1 { position:relative; left:60px;  top:25px;  width:320px; height:14px; }
.pol2 { position:relative; left:29px;  top:35px;  width:320px; height:14px; }
.pol3 { position:relative; left:125px; top:45px;  width:320px; height:14px; }
.pol4 { position:relative; left:140px; top:55px;  width:320px; height:14px; }
.polсalendar1 { position:relative; left:168px;  top:58px;  height:14px; }
.polcalendar2 { position:relative; left:208px;  top:58px;  height:14px; }

.lb1 { position:relative; left:51px;  top:25px; }
.lb2 { position:relative; left:20px;  top:35px; }
.lb3 { position:relative; left:116px; top:45px; }
.lb4 { position:relative; left:131px; top:55px; }
.lbcalendar1 { position:relative; left:162px; top:58px; }
.lbcalendar2 { position:relative; left:202px; top:58px; }

.inf0  { position:relative; left:190px; top:59px; }
.inf0_ { position:relative; left:194px; top:54px; font-size:90%;}
.inf1  { position:relative; left:186px; top:64px; }
.inf1_ { position:relative; left:194px; top:60px; font-size:90%;}

.fileld     { position:relative; left:198px; top:58px; }
.finanses   { position:relative; left:186px; top:58px; }
.video_time { position:relative; left:186px; top:62px; margin-bottom: 2px; }
.video_time2{ position:relative; left:186px; top:68px; }
.dogovor    { position:relative; left:180px; top:15px; }

.result { position:relative; left:180px; top:70px; }
</style>
function chbx()
{ if (fcheck.checked) {loadfile.disabled=false; } else {loadfile.disabled=true; } }
</script>
<script type="text/javascript">
</script>
<script src="calendar.js"></script>
</head>
<body><table><tr><td>

<form action="saver.php" method="POST">
<label class="lb1" id="LBLcompany">Название компании: </label>
<input class="pol1" id="company" name="company" type="text" size="60" onfocus="fcs(this)" onblur="blr(this)" value=""/><br>

<label class="lb2" id="LBLname">ФИО ответственного лица: </label>
<input class="pol2" id="name" name="name"type="text" size="60" onfocus="fcs(this)" onblur="blr(this)" value=""/><br>

<label class="lb3" id="LBLphone">Телефон: </label>
<input class="pol3" id="phone" name="phone" type="text" size="60" onfocus="fcs(this)" onblur="blr(this)" value=""/><br>

<label class="lb4" id="LBLemail">E-mail: </label>
<input class="pol4" id="email" name="phone" type="text" size="60" onfocus="fcs(this)" onblur="blr(this)" value=""/><br>

<label class="inf0"><b>Выберите период рекламной кампании:</b></label><br>
<label class="inf0_"><i>(нажмите на поле - появится календарь)</i></label><br>
<label class="lbcalendar1" id="LBLemail">C </label>

<input class="polсalendar1" id="cal0" name="cal0" type="text" readonly value="yy-mm-dd" onfocus="this.select();lcs(this)" onclick="event.cancelBubble=true;this.select();lcs(this)">

<label class="lbcalendar2" id="LBLemail">По </label>
<input class="polcalendar2" id="cal2" name="cal2" type="text" readonly value="yy-mm-dd" onfocus="this.select();lcs(this)" onclick="event.cancelBubble=true;this.select();lcs(this)">

<div class="video_time">
<b>Укажите длительность вашего ролика:</b><br>
<input type="radio" name="timevideo" value="5"/> 5 сек.
<input type="radio" name="timevideo" value="10"> 10 сек.
<input type="radio" name="timevideo" value="15"/> 15 сек.
<input type="radio" name="timevideo" value="20"/> 20 сек.
</div>
<div class="inf1"><input id="fcheck" onclick="chbx()" type="checkbox" value="fcheck"/><label for="fcheck"><b>Хочу загрузить рекламный ролик сейчас</b></label></div>
<label class="inf1_"><i>(вы также можете принести его в наш офис на flash или CD)</i></label><br>
<input id="loadfile" class="fileld" type="file" name="filename" disabled/>

<div class="finanses">
<b>Выберите способ оплаты:</b><br>
<input type="radio" name="pay" disabled value="bank"/> На банковский счёт
<input type="radio" name="pay"          value="nal" /> Наличными
</div>

<div><input class="result" type="submit"></div>

</form>
</td></tr></table>

</body>
</html>
Ответить с цитированием
  #2 (permalink)  
Старый 29.07.2011, 04:33
Новичок на форуме
Отправить личное сообщение для mrflow Посмотреть профиль Найти все сообщения от mrflow
 
Регистрация: 29.07.2011
Сообщений: 8

Этот скрипт подключается в строке <script src="calendar.js"></script> в HTML, который представлен выше.
СТИЛЬ ТАБЛИЦЫ описывается на 76 строке
/* --- Swazz Javascript Calendar ---
/* --- v 1.0 3rd November 2006
By Oliver Bryant
[url]http://calendar.swazz.org[/url]

Update:
Gene Bechtold
[url]http://www.bechtold.biz[/url]
31/07/2008
 */

function getObj(objID)
{
    if (document.getElementById) {return document.getElementById(objID);}
    else if (document.all) {return document.all[objID];}
    else if (document.layers) {return document.layers[objID];}
}

function checkClick(e) {
	e?evt=e:evt=event;
	CSE=evt.target?evt.target:evt.srcElement;
	if (getObj('fc'))
		if (!isChild(CSE,getObj('fc')))
			getObj('fc').style.display='none';
}

function isChild(s,d) {
	while(s) {
		if (s==d)
			return true;
		s=s.parentNode;
	}
	return false;
}

function Left(obj)
{
	var curleft = 0;
	if (obj.offsetParent)
	{
		while (obj.offsetParent)
		{
			curleft += obj.offsetLeft
			obj = obj.offsetParent;
		}
	}
	else if (obj.x)
		curleft += obj.x;
	return curleft;
}

function Top(obj)
{
	var curtop = 0;
	if (obj.offsetParent)
	{
		while (obj.offsetParent)
		{
			curtop += obj.offsetTop
			obj = obj.offsetParent;
		}
	}
	else if (obj.y)
		curtop += obj.y;
	return curtop;
}

// Calendar script
var now = new Date;
var sccd=now.getDate();
var sccm=now.getMonth();
var sccy=now.getFullYear();
var ccm=now.getMonth();
var ccy=now.getFullYear();

document.write('<table id="fc" style="position:relative;left:0px;top:338px;border-collapse:collapse;background:#FFFFFF;border:1px solid #303030;-moz-user-select:none;display:none;-khtml-user-select:none;user-select:none;" cellpadding=2>');
document.write('<tr style="font:bold 13px Arial"><td style="cursor:pointer;font-size:15px" onclick="csubm()">&laquo;</td><td colspan="5" id="mns" align="center"></td><td align="right" style="cursor:pointer;font-size:15px" onclick="caddm()">&raquo;</td></tr>');
document.write('<tr style="background:#000000;font:12px Arial;color:#FFFFFF"><td align=center>Пн</td><td align=center>Вт</td><td align=center>Ср</td><td align=center>Чт</td><td align=center>Пт</td><td align=center>Сб</td><td align=center>Вс</td></tr>');
for(var kk=1;kk<=6;kk++) {
	document.write('<tr>');
	for(var tt=1;tt<=7;tt++) {
		num=7 * (kk-1) - (-tt);
		document.write('<td id="v' + num + '" style="width:18px;height:18px">&nbsp;</td>');
	}
	document.write('</tr>');
}
document.write('<tr><td colspan="7" align="center" style="cursor:pointer;font:13px Arial;color:#FFFFFF background:#323232"  onclick="today()">Сегодня: '+addnull(sccd,sccm+1,sccy)+'</td></tr>');
document.write('</table>');

document.all?document.attachEvent('onclick',checkClick):document.addEventListener('click',checkClick,false);




var updobj;
function lcs(ielem) {
	updobj=ielem;
	getObj('fc').style.left=Left(ielem)
	getObj('fc').style.top=Top(ielem)-ielem.offsetHeight;
	getObj('fc').style.display='';

	// First check date is valid
	curdt=ielem.value;
	curdtarr=curdt.split('-');
	isdt=true;
	for(var k=0;k<curdtarr.length;k++) {
		if (isNaN(curdtarr[k]))
			isdt=false;
	}
	if (isdt&(curdtarr.length==3)) {
		ccm=curdtarr[1]-1;
		ccy=curdtarr[2];
		prepcalendar(curdtarr[0],curdtarr[1]-1,curdtarr[2]);
	}

}

function evtTgt(e)
{
	var el;
	if(e.target)el=e.target;
	else if(e.srcElement)el=e.srcElement;
	if(el.nodeType==3)el=el.parentNode; // defeat Safari bug
	return el;
}
function EvtObj(e){if(!e)e=window.event;return e;}
function cs_over(e) {
	evtTgt(EvtObj(e)).style.background='#bebebe';
    evtTgt(EvtObj(e)).style.fontWeight='bold';
    evtTgt(EvtObj(e)).style.font='12px Arial';
}
function cs_out(e) {
	evtTgt(EvtObj(e)).style.background='#FFFFFF';
    evtTgt(EvtObj(e)).style.fontWeight='normal';
    evtTgt(EvtObj(e)).style.font='10px Arial';
}
function cs_click(e) {
	updobj.value=calvalarr[evtTgt(EvtObj(e)).id.substring(1,evtTgt(EvtObj(e)).id.length)];
	getObj('fc').style.display='none';
}

var mn=new Array('Январь','Февраль','Март','Апрель','Май','Июнь','Июль','Август','Сентябрь','Октябрь','Ноябрь','Декабрь');
var mnn=new Array('31','28','31','30','31','30','31','31','30','31','30','31');
var mnl=new Array('31','29','31','30','31','30','31','31','30','31','30','31');
var calvalarr=new Array(42);

function f_cps(obj) {
	obj.style.background='#FFFFFF';
	obj.style.font='10px Arial';
	obj.style.color='#000000';
	obj.style.textAlign='center';
	obj.style.textDecoration='none';
	obj.style.border='1px solid #606060';
	obj.style.cursor='pointer';
}

function f_cpps(obj) {
	obj.style.background='#C4D3EA';
	obj.style.font='10px Arial';
	obj.style.color='#FFFFFF';
	obj.style.textAlign='center';
	obj.style.textDecoration='line-through';
	obj.style.border='1px solid #6487AE';
	obj.style.cursor='default';
}

function f_hds(obj) {
	obj.style.background='#000000';
	obj.style.font='bold 10px Arial';
	obj.style.color='#FFFFFF';
	obj.style.textAlign='center';
	obj.style.border='1px solid #6487AE';
	obj.style.cursor='pointer';
}

// day selected
function prepcalendar ( hd, cm, cy )
{
	now=new Date();
	sd=now.getDate();
	td=new Date();
	td.setDate(1);
	td.setFullYear(cy);
	td.setMonth(cm);
	cd=td.getDay();
	if (cd==0)cd=6; else cd--;

	getObj('mns').innerHTML=mn[cm]+ ' ' + cy;

	marr=((cy%4)==0)?mnl:mnn;

	for(var d=1;d<=42;d++)
	{
		f_cps ( getObj ( 'v' + parseInt ( d ) ) );
		if ( ( d >= (cd -(-1) ) ) && ( d<=cd-(-marr[cm]) ) )
		{
			getObj('v'+parseInt(d)).onmouseover=cs_over;
			getObj('v'+parseInt(d)).onmouseout=cs_out;
			getObj('v'+parseInt(d)).onclick=cs_click;

			// if today
			if (sccm == cm && sccd == (d-cd) && sccy == cy)
				getObj('v'+parseInt(d)).style.color='#ff0000';
			getObj('v'+parseInt(d)).innerHTML=d-cd;

			calvalarr[d]=addnull(d-cd,cm-(-1),cy);
		}
		else
		{
			getObj('v'+d).innerHTML='&nbsp;';
			getObj('v'+parseInt(d)).onmouseover=null;
			getObj('v'+parseInt(d)).onmouseout=null;
			getObj('v'+parseInt(d)).onclick=null;
			getObj('v'+parseInt(d)).style.cursor='default';
		}
	}
}

prepcalendar('',ccm,ccy);

function caddm() {
	marr=((ccy%4)==0)?mnl:mnn;

	ccm+=1;
	if (ccm>=12) {
		ccm=0;
		ccy++;
	}
	prepcalendar('',ccm,ccy);
}

function csubm() {
	marr=((ccy%4)==0)?mnl:mnn;

	ccm-=1;
	if (ccm<0) {
		ccm=11;
		ccy--;
	}
	prepcalendar('',ccm,ccy);
}

function today() {
	updobj.value=addnull(now.getDate(),now.getMonth()+1,now.getFullYear());
	getObj('fc').style.display='none';
	prepcalendar('',sccm,sccy);
}

function addnull(d,m,y)
{
	var d0='',m0='';
	if (d<10)d0='0';
	if (m<10)m0='0';

	return ''+d0+d+'.'+m0+m+'.'+y;
}


Нажмите на эту фигню) не знаю, почему нет превью)


Плюс к этому хотелось бы спросить, как вычесть две даты на этой же странице?

Последний раз редактировалось mrflow, 29.07.2011 в 04:40.
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Динамическая форма... AnggelofDem Элементы интерфейса 9 06.06.2011 09:42
Динамическая форма AnggelofDem Работа 12 06.06.2011 09:41
ТЕМЫ ОФОРМЛЕНИЯ, ДВИГАЮЩАЯСЯ ФОРМА alex_89 Элементы интерфейса 2 01.05.2011 20:30
Всплывающая форма в центре страницы для гостевой книги angel-13th Элементы интерфейса 8 05.02.2011 20:10
Появляющаяся форма при нажатии на чекбокс bananapapa Общие вопросы Javascript 1 21.07.2010 09:39