1. DOM 지금은 WEB 표준이 많이 대중화되어 있는데, 아래에서 다루고 있는 것은 그 표준에 맞지 않는 document.all[] 입니다. DOM - DOCUMENT OBJECT MODEL 문서 객체 모델은 문서 객체에 액세스하는 방법을 제공합니다. 예를 들어 문서에 테이블이 있고 배경색을 변경하려는 경우 document.all[]을 사용하여 자바스크립트에서 TABLE에 액세스할 수 있습니다. 그러나 DOM도 다릅니다. 브라우저 제조업체 간의 경쟁으로 인해 각 브라우저 제조업체는 자체 브라우저에서만 올바르게 실행될 수 있는 자체 비공개 DOM을 개발했습니다. document.all[]은 Microsoft의 비공개 DOM에서만 실행될 수 있습니다. DOM을 정확하게 이해하기 위해 IE4의 DOM을
줍니다. 2. document.all[]을 이해합니다.
IE4부터 IE의 객체 모델은 document만 추가했습니다. .all[ ], document.all[]의 설명을 살펴보겠습니다.
문서에 있는 모든 HTML 태그의 배열.객체에 포함된 모든 요소의 컬렉션
즉. , document.all[]은 문서 개체의 모든 요소를 포함하여 의 모든 태그로 구성된 배열 변수입니다(예제 1 참조).
IE의 document.all 컬렉션은 문서의 모든 요소에 대한 액세스를 제공합니다.
document.all[] 이 배열은 문서의 모든 요소에 대한 액세스를 제공합니다.
예 1(문서에 어떤 개체가 있는지 이해할 수 있음)
]
ã ìì 2 (í¹ì ììì ì ê·¼)
ì¸ë¶ J를 ëì
í´ì¼ íë ê²½ì° ì¤ííë ¤ë©´ ìë¡ ê³ ì³ì¼ í©ëë¤
]
ìì ì를 íµí´ 문ìì í¹ì ììì ì¡ì¸ì¤íë ë°©ë²ì ì´í´í ì ììµëë¤. ì를 ë¤ì´
를 ì¬ì©í ì ììµëë¤. DIVì ID, NAME ëë INDEX ìì±ì ì¬ì©íì¬ ì´ DIVì ì¡ì¸ì¤í ì ììµëë¤.
ì½ëë ë¤ìê³¼ ê°ìµëë¤.
document.all["docid"]
document.all["docname"]
document.all.item("docid")
document.all.item("docname")
document.all[7] document.all.tags("div")ë 문ìì ìë 모ë DIVì ë°°ì´ì ë°íí©ëë¤. íëì DIVë§ ìì¼ë¯ë¡ document.all.tags("div")[0] ì ì¬ì©íì¬ ì¡ì¸ì¤í ì ììµëë¤.
ãã3ã使ç¨document.all[]
ä¾3
ãã
4ãæ åDOMä¸ç访é®æ¹æ³ ããå¼å¤´å°±è¯´è¿document.all[]ä¸ç¬¦åWEBæ åï¼é£ç¨ä»ä¹æ¥æ¿ä»£å®å¢ï¼document.getElementById
Most third-party browsers are âstrict standardsâ implementations, meaning that they implement W3C and ECMA standards and ignore most of the proprietary object models of Internet Explorer and Netscape.If the demographic for your Web site includes users likely to use less common browsers, such as Linux aficionados, it might be a good idea to avoid IE-specific features and use the W3C DOM instead. by Internet Explorer 6, we see that IE implements significant portions of the W3C DOM.
ããè¿æ®µè¯çæææ¯å¤§å¤æ°ç¬¬ä¸æ¹æµè§å¨åªæ¯æW3CçDOMï¼å¦æä½ çç½ç«ç¨æ·ä½¿ç¨å
¶ä»çæµè§å¨ï¼é£ä¹ä½ æ好é¿å
使ç¨IEçç§æå±æ§ãèä¸IE6ä¹å¼å§æ¯æW3CãDOMã
ããæ¯ç«å¤§å¤æ°äººè¿ä¸äºè§£æ åï¼å¨ä½¿ç¨æ ååï¼ä½ è¿å¯ä»¥å¨ä½ çç½é¡µä¸ç¨document.all[]访é®æ档对象åé¢åå°WEBæ åï¼ä»å¤©ç»§ç»WEBæ åä¸å¯ä»¥éè¿getElementById(), getElementsByName(), and getElementsByTagName()访é®DOCUMENTä¸çä»»ä¸ä¸ªæ ç¾ï¼
ãã1ãgetElementById()
ããgetElementById()å¯ä»¥è®¿é®DOCUMENTä¸çæä¸ç¹å®å
ç´ ï¼é¡¾åæä¹ï¼å°±æ¯éè¿IDæ¥åå¾å
ç´ ï¼æ以åªè½è®¿é®è®¾ç½®äºIDçå
ç´ ã
ããæ¯å¦è¯´æä¸ä¸ªDIVçID为docidï¼
ããé£ä¹å°±å¯ä»¥ç¨getElementById("docid")æ¥è·å¾è¿ä¸ªå
ç´ ã
ãã
2ãgetElementsByName()
ããè¿ä¸ªæ¯éè¿NAMEæ¥è·å¾å
ç´ ï¼ä½ä¸ç¥å¤§å®¶æ³¨æ没æï¼è¿ä¸ªæ¯GETãELEMENTSï¼å¤æ°ELEMENTS代表è·å¾çä¸æ¯ä¸ä¸ªå
ç´ ï¼ä¸ºä»ä¹å¢ï¼
ããå 为DOCUMENTä¸æ¯ä¸ä¸ªå
ç´ çIDæ¯å¯ä¸çï¼ä½NAMEå´å¯ä»¥éå¤ãæ个æ¯å»å°±å人ç身份è¯å·æ¯å¯ä¸çï¼ç论ä¸ï¼è½ç¶ç°å®ä¸æéå¤ï¼ï¼ä½ååéå¤çå´å¾å¤ãå¦æä¸ä¸ªææ¡£ä¸æ两个以ä¸çæ ç¾NAMEç¸åï¼é£ä¹getElementsByName()å°±å¯ä»¥åå¾è¿äºå
ç´ ç»æä¸ä¸ªæ°ç»ã
ããæ¯å¦æ两个DIVï¼
ããé£ä¹å¯ä»¥ç¨getElementsByName("docname")è·å¾è¿ä¸¤ä¸ªDIVï¼ç¨getElementsByName("docname")[0]访é®ç¬¬ä¸ä¸ªDIVï¼ç¨getElementsByName("docname")[1]访é®ç¬¬äºä¸ªDIVã
ããä¸é¢è¿æ®µè¯æéï¼è¯·çforforçåå¤ï¼ä½æ¯å¾å¯æï¼IE没ææ¯æè¿ä¸ªæ¹æ³ï¼å¤§å®¶æå
´è¶£å¯ä»¥å¨FIREFOXæNETSCAPEä¸è°è¯ä¸é¢è¿ä¸ªä¾åãï¼æå¨NETSCAPE7.2è±æçåFIREFOX1.0ä¸è°è¯æåãï¼
ããçæ¥ææ°çæµè§å¨ç解WEBæ åè¿æ¯æé®é¢ï¼æç¥éçåªæç模åãç©ºæ ¼BUGãæ¼æµ®BUGãFLASHæå
¥BUGï¼ä»document.getElementsByNameå¯ä»¥çåºFIREFOXï¼NETSCAPEç解æ åæåå·®ï¼ä½forfor说ç对ï¼è¦çµæ´»åºç¨æ åã
ãã3ãgetElementsByTagName() ããè¿ä¸ªå¢å°±æ¯éè¿TAGNAMEï¼æ ç¾å称ï¼æ¥è·å¾å
ç´ ï¼ä¸ä¸ªDOCUMENTä¸å½ç¶ä¼æç¸åçæ ç¾ï¼æ以è¿ä¸ªæ¹æ³ä¹æ¯åå¾ä¸ä¸ªæ°ç»ã
ããä¸é¢è¿ä¸ªä¾åæ两个DIVï¼å¯ä»¥ç¨getElementsByTagName("div")æ¥è®¿é®å®ä»¬ï¼ç¨getElementsByTagName("div")[0]访é®ç¬¬ä¸ä¸ªDIVï¼ç¨
getElementsByTagName("div")[1]访é®ç¬¬äºä¸ªDIVã
ããæ»ç»ä¸ä¸æ åDOMï¼è®¿é®æä¸ç¹å®å
ç´ å°½éç¨æ åçgetElementById()ï¼è®¿é®æ ç¾ç¨æ åçgetElementByTagName(),ä½IEä¸æ¯ægetElementsByName()ï¼æ以就è¦é¿å
使ç¨getElementsByName()ï¼ä½getElementsByName()åä¸ç¬¦åæ åçdocument.all[]ä¹ä¸æ¯å
¨æ æ¯å¤ï¼å®ä»¬æèªå·±çæ¹ä¾¿ä¹å¤ï¼ç¨ä¸ç¨é£å°±çç½ç«çç¨æ·ä½¿ç¨ä»ä¹æµè§å¨ï¼ç±ä½ èªå·±å³å®äºã
ããå
³äºdocument.getElementsByName
ããIEå½ç¶æ¯æ å¯ä»¥è¯´IEæ´å¿ äºhtml/xhtmlæ å(å¿å¿ åæ¥firefoxä¹ä¸åå° å¹¸ç¾ä¹ç¥¸ä¸ä¸^_^)
ããæç
§O'REILLYç<>ä¸çè¯´æ³ name并ä¸æ¯æ ¸å¿å±æ§ 并éæææ ç¾é½å¯ä»¥å nameå±æ§(大家å¯ä»¥æ¿æä¸é¢çä¾åå» validator.w3.org åéªè¯)
ããæä»¥ä½ ç»divå nameå±æ§ç论ä¸æ¯ä¸ä¼åºç»æç.è¿ä¸ç¹IEå¾å¥½ç符åäºæ å~!!
ãã(åæ¶ä¹çåºäºç¬¦åæ åä¹æç¦äººçå°æ¹~_~ æ以大家ä¸ç¨å¤ªææ åå½åäºå¿ è¿ä¸¤å¹´é½ç¨xmläº è¿ä¸ªä¹è¿æ¶äº!å¡å¯¼çµæ´»çwebstandardåºç¨ææ³ é¤äºç¬¦åxmlææ³çä¸è¥¿ å
¶ä»çææµè§å¨çç解å»åå°±è¡)
é:
ããç®åæ¥è¯´å°±æ¯DIVä¸æ¯æNAMEå±æ§ï¼æ以é£ä¸ªdocument.getElementsByNameçä¾åè°è¯ä¸è½éè¿.
ä¸é¢ç¨INPUTå个ä¾å