1 / 40

D ocument O bject M odel (DOM)

D ocument O bject M odel (DOM). Programação na Internet Secção de Sistemas e Tecnologias de Informação ISEL-DEETC-LEIC Luis Falcão - lfalcao@cc.isel.ipl.pt Carlos Guedes – cguedes@cc.isel.ipl.pt Nuno Datia – datia@isel.ipl.pt. Autores e contributos. Autores Luís Falcão

Télécharger la présentation

D ocument O bject M odel (DOM)

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Document Object Model(DOM) Programação na Internet Secção de Sistemas e Tecnologias de Informação ISEL-DEETC-LEIC Luis Falcão - lfalcao@cc.isel.ipl.pt Carlos Guedes – cguedes@cc.isel.ipl.pt Nuno Datia – datia@isel.ipl.pt

  2. Autores e contributos • Autores • Luís Falcão • Contributos • Paulo Pereira • Pedro Félix • Jorge Martins • Carlos Guedes • Nuno Datia DOM: Document Object Model 2

  3. DOM – Introdução • API para acesso aos elementos de um documento HTML e XML, bem formado (well-formed). • Define a estrutura lógica dos documentos e a forma de acesso e manipulação. • O DOM permite: • Criar documentos • Navegar através da sua estrutura • Adicionar, remover e modificar elementos e o seu conteúdo • Aceder a todo (com algumas excepções, por enquanto) o conteúdo de um documento (HTML e XML) • A especificação DOM define uma interface independente de qualquer linguagem e plataforma (definida em IDL da OMG, definido no CORBA 2.2). • URL da especificação DOM: http://www.w3.org/DOM/ DOM: Document Object Model

  4. Características básicas do DOM • O modelo de objectos é independente de qualquer linguagem e plataforma. • Existência de uma interface base no DOM que é aplicável a documentos HTML, CSS e XML. • O modelo de objectos pode ser utilizado para construir e destruir um documento. • Não exclui a possibilidade de utilização do modelo de objectos por agentes externos ao documento, ou a script embebido no documento. • Utilização de convenções de nomes entre os vários níveis de DOM. • Uma implementação DOM não necessita de criar componentes visuais. • Os objectos específicos para documentos HTML, CSS e XML são definidos pelos elementos dessas linguagens. • Permitir ler um documento e criar outro com a mesma estrutura. • Não expõe o utilizador a problemas relacionados com segurança, validade, ou privacidade. • Não exclui a possibilidade de existência de outros mecanismos para manipular os documentos. DOM: Document Object Model

  5. Níveis de DOM • Actividades iniciadas em Agosto de 1997. • A especificação DOM foi dividida em vários níveis (actualmente 3). Cada nível trata de um conjunto de funcionalidades. • Os níveis 1, 2 e 3 já são recomendações. • O DOM Working Group não é o único do W3C que produz APIs e extensões à arquitectura DOM. Outros módulos do DOM incluem: • DOM para MathML 2.0: API genérica para documentos MathML 2.0. • DOM para animações SMIL (Synchronized Multimedia Integration Language): API genérica para animações SMIL. • DOM para SVG 1.0: API genérica para documentos SVG 1.0. DOM: Document Object Model

  6. Arquitectura DOM • A arquitectura do DOM está dividida em módulos. • Cada módulo endereça um domínio específico. • Os domínios cobertos “actualmente” pela API DOM são: • DOM Core • DOM XML • DOM HTML • DOM Events • DOM CSS • DOM LoadandSave • DOM Validation • DOM XPath DOM: Document Object Model

  7. DOM Nível 1 • DOM Nível1(especificação desde Outubro de 1998) • Navegação sobre a estrutura do documento • Manipulação do documento • Manipulação do conteúdo DOM: Document Object Model

  8. DOM Nível 2 • DOM Nível2 (recomendação desde Novembro de 2000) • Extensões ao nível 1 para suportar XML 1.0 Namespaces(DocumentObjectModelLevel 2 Core ) • Modelo de objectos para as CascadingStyleSheets(DocumentObjectModelLevel 2 Style) • Modelo de eventos para user interfaces e de manipulação do documento(DocumentObjectModelLevel 2 Events) • Possibilidade de ter visão linear e filtrada um documento (DocumentObjectModelLevel 2 Traversaland Range) • Especificação baseada no DOM Nível 2 Core e não compatível com a DOM Nível 1 HTML (DocumentObjectModelLevel 2 HTML) • Manipulação do aspecto visual de um documento (DocumentObjectModelLevel 2 Views) DOM: Document Object Model

  9. DOM Nível 2 - Arquitectura

  10. DOM Nível 3 • DOM Nível3 (já é uma recomendação) • Extensões ao nível 2 para suporte total dos Namespaces XML 1.0 • (Document Object Model Level 3 Core) • Load and Save • (Document Object Model Level 3 Load and Save) • Validações • (Document Object Model Level 3 Validation) • Eventos • (Document Object Model Level 3 Events) • XPath • (Document Object Model Level 3 XPath) DOM: Document Object Model

  11. DOM Nível 3 Arquitectura

  12. DOM Nível 3 Arquitectura (final)

  13. DOM – O que é? <TABLE> <TBODY> <TR> <TD>Shady Grove</TD> <TD>Aeolian</TD> </TR> <TR> <TD>Over the River, Charlie</TD> <TD>Dorian</TD> </TR> </TBODY> </TABLE> • API para acesso ao conteúdo de um documento. • Estrutura de objectos que espelha a estrutura do documento original. • O modelo de objectos DOM define: • As interfaces e os objectos utilizados para representar os elementos de um documento. • A semântica dessas interfaces. • As relações e colaborações entre interfaces e objectos. DOM: Document Object Model

  14. DOM – O quenão é? Embora fortemente influenciado pelo “Dynamic HTML Object Model” (DOM Nível 0), não implementa toda a sua funcionalidade no Nível 1. Não é uma especificação binária (tipo COM ou CORBA). Tem que ser feita uma adaptação (mapeamento) para cada linguagem. Não define como é que objectos são representados em XML ou HTML. Em vez disso define como é que documentos HTML e XML são representados na forma de objectos. Não é um conjunto de estruturas de dados. É um modelo de objectos que define interfaces. A API define apenas relações lógicas entre interfaces, não sugerindo nenhuma estrutura física para a implementação. Não define qual a informação que é relevante num documento, nem como esta deve ser estruturada. Não é um competidor do COM ou CORBA. Pode ser implementado utilizando qualquer um destes sistemas de objectos (ou não). DOM: Document Object Model

  15. Tipos e interfaces Básicas (1) DOMString DOMImplementation typedef sequence<unsigned short> DOMString; interfaceDOMImplementation { boolean hasFeature(in DOMString feature, in DOMString version); }; DOMException exceptionDOMException { unsigned short code; }; // ExceptionCode const unsigned short INDEX_SIZE_ERR = 1; const unsigned short DOMSTRING_SIZE_ERR = 2; const unsigned short HIERARCHY_REQUEST_ERR = 3; const unsigned short WRONG_DOCUMENT_ERR = 4; const unsigned short INVALID_CHARACTER_ERR = 5; const unsigned short NO_DATA_ALLOWED_ERR = 6; const unsigned short NO_MODIFICATION_ALLOWED_ERR = 7; const unsigned short NOT_FOUND_ERR = 8; const unsigned short NOT_SUPPORTED_ERR = 9; const unsigned short INUSE_ATTRIBUTE_ERR = 10; DOMFragment interfaceDocumentFragment : Node { }; DOM: Document Object Model

  16. Interface Document Node Document Document interfaceDocument : Node { // Attributes readonlyattribute DocumentType doctype; readonlyattribute DOMImplementation implementation; readonlyattribute Element documentElement; // Methods Element createElement(in DOMString tagName) raises(DOMException); DocumentFragment createDocumentFragment(); Text createTextNode(in DOMString data); Comment createComment(in DOMString data); CDATASection createCDATASection(in DOMString data) raises(DOMException); ProcessingInstruction createProcessingInstruction (in DOMString target, in DOMString data) raises(DOMException); Attr createAttribute(in DOMString name) raises(DOMException); EntityReference createEntityReference (in DOMString name) raises(DOMException); Element getElementById(in DOMString idname); // DOM Level 2 NodeList getElementsByTagName(in DOMString tagname); };

  17. Interface Node- Constantes Node Node interfaceNode { // Constants // NodeType const unsigned short ELEMENT_NODE = 1; const unsigned short ATTRIBUTE_NODE = 2; const unsigned short TEXT_NODE = 3; const unsigned short CDATA_SECTION_NODE = 4; const unsigned short ENTITY_REFERENCE_NODE = 5; const unsigned short ENTITY_NODE = 6; const unsigned short PROCESSING_INSTRUCTION_NODE = 7; const unsigned short COMMENT_NODE = 8; const unsigned short DOCUMENT_NODE = 9; const unsigned short DOCUMENT_TYPE_NODE = 10; const unsigned short DOCUMENT_FRAGMENT_NODE = 11; const unsigned short NOTATION_NODE = 12; ... };

  18. Interface Node- Atributos Node Valores de nodeName, nodeValue e attributes, consoante o tipo de elemento interfaceNode { ... // Attributes readonly attribute unsignedshort nodeType; readonly attribute Node parentNode; readonly attribute NodeList childNodes; readonly attribute Node firstChild; readonly attribute Node lastChild; readonly attribute Node previousSibling; readonly attribute Node nextSibling; readonly attribute Document ownerDocument; readonly attribute DOMString nodeName; attribute DOMString nodeValue; readonly attribute NamedNodeMap attributes; };

  19. Interface Node- Métodos Node interfaceNode { ... // Methods Node insertBefore(in Node newChild, in Node refChild) raises(DOMException); Node replaceChild(in Node newChild, in Node oldChild) raises(DOMException); Node removeChild(in Node oldChild) raises(DOMException); Node appendChild(in Node newChild) raises(DOMException); boolean hasChildNodes(); Node cloneNode(inboolean deep) raises(DOMException); };

  20. Interfaces NodeList e NamedNodeMap NodeList interfaceNodeList { // Attributes readonlyattributeunsigned long length; // Methods Node item(inunsigned long index); // x[index] }; NamedNodeMap interfaceNamedNodeMap { // Attributes readonly attribute unsigned long length; // Methods Node getNamedItem(in DOMString name); Node setNamedItem(in Node arg) raises(DOMException); Node removeNamedItem(in DOMString name) raises(DOMException); Node item(inunsigned long index); // x[index] };

  21. Interface Attr Node Attr Attr • interfaceAttr : Node { • readonly attribute DOMString name; • readonly attribute boolean specified; • // Modified in DOM Level 1: • attribute DOMString value; • };

  22. Interface Element Node Element Element interfaceElement : Node { readonly attribute DOMString tagName; DOMString getAttribute(in DOMString name); void setAttribute(in DOMString name, in DOMString value) raises(DOMException); void removeAttribute(in DOMString name) raises(DOMException); Attr getAttributeNode(in DOMString name); Attr setAttributeNode(in Attr newAttr) raises(DOMException); Attr removeAttributeNode(in Attr oldAttr) raises(DOMException); NodeList getElementsByTagName(in DOMString name); // * means all Tags void normalize(); };

  23. Interface CharacterData Node CharacterData CharacterData interfaceCharacterData : Node { attribute DOMString data; // raises(DOMException) on setting and retrieval readonly attribute unsigned long length; DOMString substringData (inunsigned long offset, in unsigned long count) raises(DOMException); void appendData (in DOMString arg) raises(DOMException); void insertData (inunsigned long offset, in DOMString arg) raises(DOMException); void deleteData (inunsigned long offset, inunsignedlong count) raises(DOMException); void replaceData (inunsigned long offset, inunsignedlong count, in DOMString arg) raises(DOMException); };

  24. Interfaces Texte Comment Node Text CharacterData interfaceText : CharacterData { Text splitText(in unsignedlong offset) raises(DOMException); }; Text Comment Comment interfaceComment : CharacterData { };

  25. Interfaces DOM para HTML • Extensões às interfaces básicas DOM, específicas para documentos HTML. • Na interface básica, são disponibilizadas todas as funcionalidades que permitem: • Manipulação da estrutura hierárquica dos documentos. • Manipulação de elementos. • Manipulação de atributos. • Na interface DOM para HTMLsão disponibilizadas funcionalidades que dependem das especificidades dos elementos do HTML. Os objectivos desta API são: • Especialização de funcionalidades relacionadas com os elementos HTML. • Manutenção de compatibilidade com DOM Nível 0 (DHTML). • Oferecer mecanismos para implementar as operações mais frequentes sobre documentos HTML (sempre que se justifique). • Esta API não é obrigatória numa implementação DOM nível 1. Caso a implementação suporte estas interfaces, deve responder true no métodohasFeature de DOMImplementation, quando recebe como parâmetros asstrings “HTML” e “1.0”. DOM: Document Object Model

  26. Interface HTMLCollection HTMLCollection interfaceHTMLCollection { readonlyattribute unsigned long length; Node item(inunsignedlong index); // nodeName corresponds to HTML attribute “id” or “name” Node namedItem(in DOMString nodeName); };

  27. Interface HTMLDocument Node HTMLDocument • interfaceHTMLDocument : Document { • attribute DOMString title; • readonly attribute DOMString referrer; • readonly attribute DOMString domain; • readonly attribute DOMString URL; • attribute HTMLElement body; • readonlyattribute HTMLCollection images; • readonlyattribute HTMLCollection applets; • readonlyattribute HTMLCollection links; • readonlyattribute HTMLCollection forms; • readonlyattribute HTMLCollection anchors; • attribute DOMString cookie; • void open(); • void close(); • void write(in DOMString text); • void writeln(in DOMString text); • Element getElementById(in DOMString elementId); • NodeList getElementsByName(in DOMString elementName); • }; Document HTMLDocument

  28. Interface HTMLElement Node HTMLElement • interfaceHTMLElement : Element { • attribute DOMString id; • attribute DOMString title; • attribute DOMString lang; • attribute DOMString dir; • attribute DOMString className; • }; Element HTMLElement Elementos HTML que apenas disponibilizam a interface básica HTMLElement: • HEAD • special: SUB, SUP, SPAN, BDO • font: TT, I, B, U, S, STRIKE, BIG, SMALL • phrase: EM, STRONG, DFN, CODE, SAMP, KBD, VAR, CITE, ACRONYM, ABBR • list: DD, DT • NOFRAMES, NOSCRIPT • ADDRESS, CENTER DOM: Document Object Model

  29. Interfaces para outros elementos do HTML Node Element HTMLElement HTMLMetaElement HTMLLinkElement HTMLHeadElement HTMLHtmlElement HTMLBodyElement HTMLTitleElement HTMLBaseElement HTMLStyleElement HTMLFormElement

  30. DOM 2 – Modelo de Eventos • Sistema de eventos genérico que • Permite o registo de handlers de eventos • Fornece conjuntos de eventos para a controlo da UI e para notificação da alteração da estrutura do documento • Define a informação contextual para cada um dos tipos de eventos • Contém como subconjunto, os eventos utilizados no DOM nível 0 • Existem várias técnicas para gerir a captura de eventos • É possível a um evento ser capturado ao longo de um caminho na árvore DOM DOM: Document Object Model

  31. Event Flow Capture Bubbling • Existem duas fases no processamento de eventos: • Capture – A primeira das fases, onde o evento percorre a árvore do documento, desde a raiz até ao elemento a que é destinado o evento • Bubble – Processo contrário, onde o evento depois de processado pelo elemento a que se destinava, é passado para o nó pai, afim de ser processado DOM: Document Object Model

  32. Interfaces de registo de Eventos EventTarget interfaceCharacterData : Node { voidaddEventListener(in DOMString type, in EventListener listener, in boolean useCapture); voidremoveEventListener(in DOMString type, in EventListener listener, in boolean useCapture); booleandispatchEvent(in Event evt) raises(EventException); }; EventListener interface EventListener { void handleEvent(in Event evt); }; DOM: Document Object Model

  33. Registo de Handlers Da forma clássica window.onload = function () { alert(“página carregada!”);} W3C DOM window.addEventListener(“load”, function () { alert(“página carregada!”);}, false); • O registo de handlers é efectuado sobre o objecto “gerador” de eventos: • node.["on" + type] = f; • node.addEventListener(type, f, false); Atenção! • Nos browsers que não implementam o especificação DOM nível 2 para eventos (e.g. Microsoft IE), a forma de registo anterior não funciona DOM: Document Object Model

  34. Captura de Eventos div.addEventListener(“click”, function () { alert(“página carregada!”);}, true); • Qualquer evento que seja gerado no nó <div> ou em algum dos seus descendentes, é, em primeiro lugar, notificado o nó <div> • Só depois serão notificados os nós descendentes (que tiverem capturado o evento) e finalmente o nó destinatário • É possível cancelar a captura evocando o método preventDefault (ou retornando false, no IE!) 1 2 No registo dos handlers, é possível especificar se é pretendido capturar o evento antes de ele ser processado pelo nó destinatário DOM: Document Object Model

  35. Bubbling div.addEventListener(“click”, function () { alert(“página carregada!”);}, false); • É possível evitar que o evento seja propagado para os ascendentes – evocando o método stopPropagation • Note-se que nem todos os eventos suportam bubbling (e.g load) e nem todos podem ser cancelados (e.g. mousemove ) 3 2 Uma vez processado o evento pelo nó destinatário, são evocados os handlers dos nós ascendentes, pela ordem inversa da fase anterior (captura) DOM: Document Object Model

  36. Interface Evento Event interface // PhaseType const unsigned short CAPTURING_PHASE = 1; const unsigned short AT_TARGET = 2; const unsigned short BUBBLING_PHASE = 3; readonly attribute DOMString type; readonly attribute EventTarget target; readonly attribute EventTarget currentTarget; readonly attribute unsigned short eventPhase; readonly attribute boolean bubbles; readonly attribute boolean cancelable; readonly attribute DOMTimeStamp timeStamp; void stopPropagation(); void preventDefault(); void initEvent(in DOMString eventTypeArg, in boolean canBubbleArg, in boolean cancelableArg);}; DOM: Document Object Model

  37. Handlers e eventos • De acordo com a especificação DOM, é sempre passado como parâmetro ao handler o evento Atenção!!! • Nos browsers da Microsoft não é passado nenhum evento como parâmetro – tem de ser consultado o objecto global window.event DOM: Document Object Model

  38. Eventos DOM Event UIEvent MouseEvent MutationEvent • Na especificação DOM nível 2, estão definidos 3 tipos de eventos: • Eventos da User Interface • e.g. DomFocusIn • Eventos de rato • e.g. click • Eventos de alteração da estrutura do documento (Mutation Events) • e.g. DOMNodeInserted • A especificação DOM nível três define também eventos de teclado DOM: Document Object Model

  39. Eventos de Rato • Os eventos de rato são aqueles que são mais utilizados: • click, mousedown, mouseup, mouseover, mouseout, mousemove • Quando são deste tipo, os eventos contêm também as propriedades: DOM: Document Object Model

  40. Bibliografia W3C Document Object Model http://www.w3.org/DOM/ Dom Technical Reports http://www.w3.org/DOM/DOMTR 40

More Related