Kezdőoldal » Számítástechnika » Programozás » Mi a probléma? Vagy legalább...

RaiderHUN kérdése:

Mi a probléma? Vagy legalább is, hol keresendő?

Figyelt kérdés

Egy eseménynaptárat szeretnék a weblapomra, egyáltalán értek a javascripthez. Találtam egy scriptet, átdolgoztam a kinézetét és a nyelvezetét. Firefoxban teljesen tökéletesen működik is, de chomeban az utolsó sort pl ( 31 napos a május, és ez az első rublika az utolsó sorban. Akkor végig pakolja a sort 37-ig. ) Hasonlóan a többi hónapnál is.


-------------------------------------------------------


<script type="text/JavaScript" language="JavaScript">


/* Preload images script */

var myimages=new Array()


function preloadimages(){

for (i=0;i<preloadimages.arguments.length;i++){

myimages[i]=new Image();

myimages[i].src=preloadimages.arguments[i];

}

}



/* The path of images to be preloaded inside parenthesis: (Extend list as desired.) */


/***************************************************************************************

JavaScript Calendar - Digital Christian Design

//Script featured on and available at JavaScript Kit: http://www.javascriptkit.com

// Functions

changedate(): Moves to next or previous month or year, or current month depending on the button clicked.

createCalendar(): Renders the calander into the page with links for each to fill the date form filds above.


***************************************************************************************/


var thisDate = 1; // Tracks current date being written in calendar

var wordMonth = new Array("Január","Február","Március","Április","Május","Június","Július","Augusztus","Szeptember","Október","November","December");

var today = new Date(); // Date object to store the current date

var todaysDay = today.getDay() + 1; // Stores the current day number 1-7

var todaysDate = today.getDate(); // Stores the current numeric date within the month

var todaysMonth = today.getUTCMonth() + 1; // Stores the current month 1-12

var todaysYear = today.getFullYear(); // Stores the current year

var monthNum = todaysMonth; // Tracks the current month being displayed

var yearNum = todaysYear; // Tracks the current year being displayed

var firstDate = new Date(String(monthNum)+"/1/"+String(yearNum)); // Object Storing the first day of the current month

var firstDay = firstDate.getUTCDay(); // Tracks the day number 1-7 of the first day of the current month

var lastDate = new Date(String(monthNum+1)+"/0/"+String(yearNum)); // Tracks the last date of the current month

var numbDays = 0;

var calendarString = "";

var eastermonth = 0;

var easterday = 0;



function changedate(buttonpressed) {

if (buttonpressed == "prevyr") yearNum--;

else if (buttonpressed == "nextyr") yearNum++;

else if (buttonpressed == "prevmo") monthNum--;

else if (buttonpressed == "nextmo") monthNum++;

else if (buttonpressed == "return") {

monthNum = todaysMonth;

yearNum = todaysYear;

}


if (monthNum == 0) {

monthNum = 12;

yearNum--;

}

else if (monthNum == 13) {

monthNum = 1;

yearNum++

}


lastDate = new Date(String(monthNum+1)+"/0/"+String(yearNum));

numbDays = lastDate.getDate();

firstDate = new Date(String(monthNum)+"/1/"+String(yearNum));

firstDay = firstDate.getDay() + 1;

createCalendar();

return;

}



function easter(year) {

// feed in the year it returns the month and day of Easter using two GLOBAL variables: eastermonth and easterday

var a = year % 19;

var b = Math.floor(year/100);

var c = year % 100;

var d = Math.floor(b/4);

var e = b % 4;

var f = Math.floor((b+8) / 25);

var g = Math.floor((b-f+1) / 3);

var h = (19*a + b - d - g + 15) % 30;

var i = Math.floor(c/4);

var j = c % 4;

var k = (32 + 2*e + 2*i - h - j) % 7;

var m = Math.floor((a + 11*h + 22*k) / 451);

var month = Math.floor((h + k - 7*m + 114) / 31);

var day = ((h + k - 7*m +114) % 31) + 1;

eastermonth = month;

easterday = day;

}



function createCalendar() {

calendarString = '';

var daycounter = 0;

calendarString += '<table width="290" border="0" cellpadding="0" cellspacing="3">';

calendarString += '<tr>';

calendarString += '<td align=\"center\" valign=\"center\" width=\"40\" height=\"30\"><a class=\"but\" href=\"#\" onClick=\"changedate(\'prevyr\')\"><<\/a><\/td>';

calendarString += '<td align=\"center\" valign=\"center\" width=\"40\" height=\"30\"><a class=\"but\" href=\"#\" onClick=\"changedate(\'prevmo\')\"><<\/a><\/td>';

calendarString += '<td align=\"center\" valign=\"center\" height=\"30\" colspan=\"3\"><b>' + wordMonth[monthNum-1] + " " + yearNum + '<\/b><\/td>';

calendarString += '<td align=\"center\" valign=\"center\" width=\"40\" height=\"30\"><a class=\"but\" href=\"#\" onClick=\"changedate(\'nextmo\')\">><\/a><\/td>';

calendarString += '<td align=\"center\" valign=\"center\" width=\"40\" height=\"30\"><a class=\"but\" href=\"#\" onClick=\"changedate(\'nextyr\')\">><\/a><\/td>';

calendarString += '<\/tr>';

calendarString += '<tr>';

calendarString += '<td bgcolor=\"#eee\" align=\"center\" valign=\"center\" width=\"40\" height=\"22\">Va<\/td>';

calendarString += '<td bgcolor=\"#eee\" align=\"center\" valign=\"center\" width=\"40\" height=\"22\">Hé<\/td>';

calendarString += '<td bgcolor=\"#eee\" align=\"center\" valign=\"center\" width=\"40\" height=\"22\">Ke<\/td>';

calendarString += '<td bgcolor=\"#eee\" align=\"center\" valign=\"center\" width=\"40\" height=\"22\">Sz<\/td>';

calendarString += '<td bgcolor=\"#eee\" align=\"center\" valign=\"center\" width=\"40\" height=\"22\">Cs<\/td>';

calendarString += '<td bgcolor=\"#eee\" align=\"center\" valign=\"center\" width=\"40\" height=\"22\">Pé<\/td>';

calendarString += '<td bgcolor=\"#eee\" align=\"center\" valign=\"center\" width=\"40\" height=\"22\">Szo<\/td>';

calendarString += '<\/tr>';


thisDate == 1;


for (var i = 1; i <= 6; i++) {

calendarString += '<tr>';

for (var x = 1; x <= 7; x++) {

daycounter = (thisDate - firstDay)+1;

thisDate++;

if ((daycounter > numbDays) || (daycounter < 1)) {

calendarString += '<td align=\"center\" height=\"20\" width=\"40\"> <\/td>';

} else {

if (checkevents(daycounter,monthNum,yearNum,i,x) || ((todaysDay == x) && (todaysDate == daycounter) && (todaysMonth == monthNum))){

if ((todaysDay == x) && (todaysDate == daycounter) && (todaysMonth == monthNum)) {

calendarString += '<td align=\"center\" class=\"pp\" bgcolor=\"#AAFFAA\" height=\"30\" width=\"40\"><a href=\"javascript:showevents(' + daycounter + ',' + monthNum + ',' + yearNum + ',' + i + ',' + x + ')\">' + daycounter + '<\/a><\/td>';

}

else calendarString += '<td align=\"center\" class=\"pp\" bgcolor=\"#FFFFC8\" height=\"30\" width=\"40\"><a href=\"javascript:showevents(' + daycounter + ',' + monthNum + ',' + yearNum + ',' + i + ',' + x + ')\">' + daycounter + '<\/a><\/td>';

} else {

calendarString += '<td align=\"center\" bgcolor=\"#fff\" height=\"30\" class=\"nap\" width=\"40\">' + daycounter + '<\/td>';

}

}

}

calendarString += '<\/tr>';

}


calendarString += '<tr><td colspan=\"7\" nowrap align=\"center\" valign=\"center\" bgcolor=\"#EEE\" width=\"280\" height=\"30\"><a href=\"javascript:changedate(\'return\')\"><b>Mostani hónap<\/b><\/a><\/td><\/tr><\/table>';


var object=document.getElementById('calendar');

object.innerHTML= calendarString;

thisDate = 1;

}



function checkevents(day,month,year,week,dayofweek) {

var numevents = 0;

var floater = 0;


for (var i = 0; i < events.length; i++) {

if (events[i][0] == "W") {

if ((events[i][2] == dayofweek)) numevents++;

}

else if (events[i][0] == "Y") {

if ((events[i][2] == day) && (events[i][1] == month)) numevents++;

}

else if (events[i][0] == "F") {

if ((events[i][1] == 3) && (events[i][2] == 0) && (events[i][3] == 0) ) {

easter(year);

if (easterday == day && eastermonth == month) numevents++;

} else {

floater = floatingholiday(year,events[i][1],events[i][2],events[i][3]);

if ((month == 5) && (events[i][1] == 5) && (events[i][2] == 4) && (events[i][3] == 2)) {

if ((floater + 7 <= 31) && (day == floater + 7)) {

numevents++;

} else if ((floater + 7 > 31) && (day == floater)) numevents++;

} else if ((events[i][1] == month) && (floater == day)) numevents++;

}

}

else if ((events[i][2] == day) && (events[i][1] == month) && (events[i][3] == year)) {

numevents++;

}

}


if (numevents == 0) {

return false;

} else {

return true;

}

}



function showevents(day,month,year,week,dayofweek) {

var theevent = "";

var floater = 0;


for (var i = 0; i < events.length; i++) {

// First we'll process recurring events (if any):

if (events[i][0] != "") {

if (events[i][0] == "D") {

}

if (events[i][0] == "W") {

if ((events[i][2] == dayofweek)) {

theevent += month +'/'+ day +'/'+ year + ' eseményei\n';

theevent += events[i][6] + '\n';

theevent += 'Kezdődik: ' + events[i][4] + '\n';

theevent += 'Vége: ' + events[i][5] + '\n';

theevent += 'Leírás: ' + events[i][7] + '\n';

theevent += '\n -------------- \n\n';

document.forms.eventform.eventlist.value = theevent;

}

}

if (events[i][0] == "M") {

}

if (events[i][0] == "Y") {

if ((events[i][2] == day) && (events[i][1] == month)) {

theevent += month +'/'+ day +'/'+ year + ' eseményei\n';

theevent += events[i][6] + '\n';

theevent += 'Kezdődik: ' + events[i][4] + '\n';

theevent += 'Vége: ' + events[i][5] + '\n';

theevent += 'Leírás: ' + events[i][7] + '\n';

theevent += '\n -------------- \n\n';

document.forms.eventform.eventlist.value = theevent;

}

}

if (events[i][0] == "F") {

if ((events[i][1] == 3) && (events[i][2] == 0) && (events[i][3] == 0) ) {

if (easterday == day && eastermonth == month) {

theevent += month +'/'+ day +'/'+ year + ' eseményei\n';

theevent += events[i][6] + '\n';

theevent += 'Kezdődik: ' + events[i][4] + '\n';

theevent += 'Vége: ' + events[i][5] + '\n';

theevent += 'Leírás: ' + events[i][7] + '\n';

theevent += '\n -------------- \n\n';

document.forms.eventform.eventlist.value = theevent;

}

} else {

floater = floatingholiday(year,events[i][1],events[i][2],events[i][3]);


if ((month == 5) && (events[i][1] == 5) && (events[i][2] == 4) && (events[i][3] == 2)) {

if ((floater + 7 <= 31) && (day == floater + 7)) {

theevent += month +'/'+ day +'/'+ year + ' eseményei\n';

theevent += events[i][6] + '\n';

theevent += 'Kezdődik: ' + events[i][4] + '\n';

theevent += 'Vége: ' + events[i][5] + '\n';

theevent += 'Leírás: ' + events[i][7] + '\n';

theevent += '\n -------------- \n\n';

document.forms.eventform.eventlist.value = theevent;

} else if ((floater + 7 > 31) && (day == floater)) {

theevent += month +'/'+ day +'/'+ year + ' eseményei\n';

theevent += events[i][6] + '\n';

theevent += 'Kezdődik: ' + events[i][4] + '\n';

theevent += 'Vége: ' + events[i][5] + '\n';

theevent += 'Leírás: ' + events[i][7] + '\n';

theevent += '\n -------------- \n\n';

document.forms.eventform.eventlist.value = theevent;

}

} else if ((events[i][1] == month) && (floater == day)) {

theevent += month +'/'+ day +'/'+ year + ' eseményei\n';

theevent += events[i][6] + '\n';

theevent += 'Kezdődik: ' + events[i][4] + '\n';

theevent += 'Vége: ' + events[i][5] + '\n';

theevent += 'Leírás: ' + events[i][7] + '\n';

theevent += '\n -------------- \n\n';

document.forms.eventform.eventlist.value = theevent;

}

}

}

}

// Now we'll process any One Time events happening on the matching month, day, year:

else if ((events[i][2] == day) && (events[i][1] == month) && (events[i][3] == year)) {

theevent += month +'/'+ day +'/'+ year + ' eseményei\n';

theevent += events[i][6] + '\n';

theevent += 'Kezdődik: ' + events[i][4] + '\n';

theevent += 'Vége: ' + events[i][5] + '\n';

theevent += 'Leírás: ' + events[i][7] + '\n';

theevent += '\n -------------- \n\n';

document.forms.eventform.eventlist.value = theevent;

}

}

if (theevent == "") document.forms.eventform.eventlist.value = 'Nincsenek események ezen a napon.';

}



function floatingholiday(targetyr,targetmo,cardinaloccurrence,targetday) {

// Floating holidays/events of the events.js file uses:

// the Month field for the Month (here it becomes the targetmo field)

// the Day field as the Cardinal Occurrence (here it becomes the cardinaloccurrence field)

// 1=1st, 2=2nd, 3=3rd, 4=4th, 5=5th, 6=6th occurrence of the day listed next

// the Year field as the Day of the week the event/holiday falls on (here it becomes the targetday field)

// 1=Sunday, 2=Monday, 3=Tuesday, 4=Wednesday, 5=Thurday, 6=Friday, 7=Saturday

// example: "F", "1", "3", "2", = Floating holiday in January on the 3rd Monday of that month.

//

// In our code below:

// targetyr is the active year

// targetmo is the active month (1-12)

// cardinaloccurrence is the xth occurrence of the targetday (1-6)

// targetday is the day of the week the floating holiday is on

// 0=Sun; 1=Mon; 2=Tue; 3=Wed; 4=Thu; 5=Fri; 6=Sat

// Note: subtract 1 from the targetday field if the info comes from the events.js file

//

// Note:

// If Memorial Day falls on the 22nd, 23rd, or 24th, then we add 7 to the dayofmonth to the result.

//

// Example: targetyr = 2052; targetmo = 5; cardinaloccurrence = 4; targetday = 1

// This is the same as saying our floating holiday in the year 2052, is during May, on the 4th Monday

//

var firstdate = new Date(String(targetmo)+"/1/"+String(targetyr)); // Object Storing the first day of the current month.

var firstday = firstdate.getUTCDay(); // The first day (0-6) of the target month.

var dayofmonth = 0; // zero out our calendar day variable.


targetday = targetday - 1;


if (targetday >= firstday) {

cardinaloccurrence--; // Subtract 1 from cardinal day.

dayofmonth = (cardinaloccurrence * 7) + ((targetday - firstday)+1);

} else {

dayofmonth = (cardinaloccurrence * 7) + ((targetday - firstday)+1);

}

return dayofmonth;

}


</script>


</head>


<body style="background-color: transparent;" onload="changedate('return')">



<center>

<table border="0" cellpadding="0" cellspacing="0" width="290">

<tbody>

<tr>

<td style="padding: 3px;" align="center" valign="top" width="290">

<div id="calendar"><!-- Dynamically Filled --></div>

</td>

</tr>

<tr>

<td style="padding: 3px;" align="center" valign="top" width="260">

<center>

<form id="eventform" name="eventform" action="#" method="get">

<textarea name="eventlist" cols="35" rows="9" wrap="soft"></textarea>

</form>

</center>

</td>

</tr>

</tbody>

</table>

</center>


</body>

</html>


2015. jún. 1. 00:23
 1/3 A kérdező kommentje:
*egyáltalán nem értek
2015. jún. 1. 00:24
 2/3 anonim ***** válasza:

1) Totál átláthatatlan a kód a GYK miatt

2) Miért nem használsz már kész megoldást? Pl.: [link]

2015. jún. 1. 08:41
Hasznos számodra ez a válasz?
 3/3 SimkoL ***** válasza:
Szép kód :) főleg a kommentek és az ismétlődő HTML 'betétek'. Szerinted ezt a dzsungel könyvét átnézi valaki ? Legalább 'tisztázd' már le és akkor lehet te is rájössz a hibára.
2015. jún. 1. 11:49
Hasznos számodra ez a válasz?

Kapcsolódó kérdések:





Minden jog fenntartva © 2024, www.gyakorikerdesek.hu
GYIK | Szabályzat | Jogi nyilatkozat | Adatvédelem | Cookie beállítások | WebMinute Kft. | Facebook | Kapcsolat: info(kukac)gyakorikerdesek.hu

A weboldalon megjelenő anyagok nem minősülnek szerkesztői tartalomnak, előzetes ellenőrzésen nem esnek át, az üzemeltető véleményét nem tükrözik.
Ha kifogással szeretne élni valamely tartalommal kapcsolatban, kérjük jelezze e-mailes elérhetőségünkön!