לוגו אתר Fresh          
 
 
  אפשרות תפריט  ראשי     אפשרות תפריט  צ'אט     אפשרות תפריט  מבזקים     אפשרות תפריט  צור קשר     חץ שמאלה ‎print ‎"Hello World!"; if‎ ‎not rules.‎know ‎then rules.‎read(); חץ ימינה  

לך אחורה   לובי הפורומים > מחשבים > תכנות ובניית אתרים
שמור לעצמך קישור לדף זה באתרי שמירת קישורים חברתיים
תגובה
 
כלי אשכול חפש באשכול זה



  #1  
ישן 29-12-2009, 01:36
  borbabeten borbabeten אינו מחובר  
 
חבר מתאריך: 17.10.05
הודעות: 161
לא מצליח למצוא את הטעות בקוד

שלום לכולם.
יש לי את הקוד הבא ב-js :






קוד:
<SCRIPT type="text/javascript"> var xmlhttp; function ajaxFunction(x) { var x=x if(window.XMLHttpRequest) { xmlhttp=new XMLHttpRequest(); } else { xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); } xmlhttp.onreadystatechange=function() { if(xmlhttp.readyState==4) { var data=xmlhttp.responseText; document.getElementById("divp").innerHTML=data; } } var url="deletmail.php"; url+="?id="+encodeURIComponent(x); url+="&ignoreMe="+Math.random(); xmlhttp.open("GET",url,true); xmlhttp.send(null); }; function hs(x) { var x="tafn"+x if (navigator.appName=='Netscape') if (document.getElementById(x).style.visibility =="hide") document.getElementById(x).style.visibility="show"; else document.getElementById(x).style.visibility="hide"; else if (document.getElementById(x).style.display=="none") document.getElementById(x).style.display="block"; else document.getElementById(x).style.display="none"; }; </script>









כך מתבצעת הקריאה לפונציות:






קוד:
onclick="ajaxFunction(22)"









וזה נותן לי את השגיאה:
Expected ';'

למישהו יש רעיונות?
תודה מראש.

נערך לאחרונה ע"י borbabeten בתאריך 29-12-2009 בשעה 01:38.
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
  #3  
ישן 29-12-2009, 10:03
  ישראל K ישראל K אינו מחובר  
 
חבר מתאריך: 25.08.03
הודעות: 9,114
בתגובה להודעה מספר 1 שנכתבה על ידי borbabeten שמתחילה ב "לא מצליח למצוא את הטעות בקוד"

1. שורת הקוד הראשונה והאחרונה אינה קוד תקין בשפת js, זהו קוד html...י


2. נסה להחליף את קוד הפונקציה השניה בקוד זה:
קוד:
function hs(x) { var x = "tafn"+x if(navigator.appName=='Netscape') { if(document.getElementById(x).style.visibility=="hidden") document.getElementById(x).style.visibility="show"; else document.getElementById(x).style.visibility="hidden"; } else { if(document.getElementById(x).style.display=="none") document.getElementById(x).style.display="block"; else document.getElementById(x).style.display="none"; } }

השינוי העיקרי שעשיתי פה הוא הסוגריים המסולסלות בתנאי הראשי. בהעדרם, המנתח (parser) עלול להתבלבל עם התנאים המקונננים ולכן מאד לא רצוי לא לציין את הסוגריים המסולסלות כשיש קינון תנאים או לולאות.


3. יש הרבה מה לשפר בקוד הזה:

א. נראה לי שהתנאי הראשי די מיותר, וכדאי להשאיר רק את החלק השני של התנאי (הפועל על המאפיין display). י
1. בהתאם למצב העדכני של הדפדפנים בני ימינו, לא נראה לי שאין דפדפנים נפוצים שלא תומכים בערכי none ו-block של מאפיין התצוגה.
2. המאפיין ראות (visibility) בכלל משמש למטרה שונה ממאפיין התצוגה (display)

ב. אתה פונה לאלמנט מסויים לפחות פעמיים בקוד והוא אף כתוב בקוד 6 פעמים!
יעיל וגם נקי יותר לכתוב זאת כך:
קוד:
function hs(x) { var x = document.getElementById("tafn"+x); if(navigator.appName=='Netscape') { if(x.style.visibility=="hidden") x.style.visibility="show"; else x.style.visibility="hidden"; } else { if(x.style.display=="none") x.style.display="block"; else x.style.display="none"; } }

ורצוי אף כך:
קוד:
function hs(x) { var x = document.getElementById("tafn"+x).style; if(navigator.appName=='Netscape') { if(x.visibility == "hidden") x.visibility = "show"; else x.visibility = "hidden"; } else { if(x.display == "none") x.display = "block"; else x.display = "none"; } }


ג. ניתן אף לכתוב את הקוד בצורה שונה שלא בהכרח יעילה יותר, אך יהיה כנראה מי שיטען שהןא נקי וקריא יותר:
קוד:
function hs(x) { var x = document.getElementById("tafn"+x).style; if(navigator.appName=='Netscape') x.visibility = x.visibility=="hidden" ? "show" : "hidden"; else x.display = x.display=="none" ? "block" : "none"; }

הוספתי פה גם ייחוס יישיר לאובייקט style של האלמנט, מה שיחסוך לפנות אליו פעם נוספת, וגם את הביטוי הטרינרי.


4. לסיום, שמתי לב רק בשלבים האחרונים שטעית בתחביר הערך "נסתר" של המאפיין "ראות" (ב-css). י
הערך נקרא hidden ולא hide.
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
תגובה

כלי אשכול חפש באשכול זה
חפש באשכול זה:

חיפוש מתקדם
מצבי תצוגה דרג אשכול זה
דרג אשכול זה:

מזער את תיבת המידע אפשרויות משלוח הודעות
אתה לא יכול לפתוח אשכולות חדשים
אתה לא יכול להגיב לאשכולות
אתה לא יכול לצרף קבצים
אתה לא יכול לערוך את ההודעות שלך

קוד vB פעיל
קוד [IMG] פעיל
קוד HTML כבוי
מעבר לפורום



כל הזמנים המוצגים בדף זה הם לפי איזור זמן GMT +2. השעה כעת היא 06:29

הדף נוצר ב 0.04 שניות עם 12 שאילתות

הפורום מבוסס על vBulletin, גירסא 3.0.6
כל הזכויות לתוכנת הפורומים שמורות © 2025 - 2000 לחברת Jelsoft Enterprises.
כל הזכויות שמורות ל Fresh.co.il ©

צור קשר | תקנון האתר