1. The DOM is what

Dom is the abbreviation of document Object Model, which defines the standard for accessing and operating HTML and XML documents. It allows programs to dynamically change the content, structure and style of documents. Here we only study THE HTML DOM.

2.HTML DOM

We studied many data structures, such as stacks, queues, linked lists, sets, dictionaries, hashes, trees, graphs; Now we’re going to look at the HTML DOM as a tree structured data type; The following figure

  • Nodes have parentNode(parentNode except root node), childNodes(child node), and sbiling(brother node) relationships, as shown in the following figure

  • Each node is an object, since it is an object, 1. The object has methods and attributes, the following operation DOM is dependent on the relevant methods and attributes to operate, 2. You can console. Dir (node) and look at the node prototype chain. You will see six layers of _proto_ prototype objects

  • In particular, layer 5 Eventarget contains the addEventListener() method, which is the API for adding event listener operations to element nodes. Since this PAI is included in node nodes, it can be inherited to operate this method

3. Operate the HTML DOM

HTML DOM is an object, so we can use the relevant attributes and methods for DOM manipulation, that is, to add, delete, change and check the DOM. Another point is that DOM nodes contain element nodes and text nodes, which can be identified by node.nodeType.

  • Get a specific element:
  1. The document document root,
  2. Doument. DoumentElement: HTML element,
  3. Doument. Body: body element,
  4. Doument. Head: the head element,
  5. Document. all: Gets all elements
  6. Node. ChildNodes all childNodes
  7. Node. children All element nodes
  8. Node. ParentNode parent node
  9. Node. The parentElement parent element
  10. Node. previousSibling previousSibling node
  11. Node. PreviousElemnetSibling previous sibling elements
  12. Node.nextsibling Next element node
  13. .
  • Find a node API:
  1. Document.getelementbyid () : Find the DOM by ID
  2. Document. The getElementsByTagName () : the element tag
  3. Document. GetElementsByClassName () : the class name lookup
  4. Document. The getElementsByName (), through the function name attribute of the element
  5. Docmenet.queryselectori (‘#id’): Get elements by writing CSS
  6. Document. QuerySelectorAll () : to find a qualified elements
  • Add a node
  1. Create an element node: document.createElement ()
  2. Create a text node: document.createTextNode()
  3. Node.appendchild (),document.append() this defaults to unpacking the node at the end of the element, using box.. InsertBefore (div,div1), which is inserted before the first div1 node of the box node
  4. You can also add elements and nodes to the innerHtml and innerText attributes
  • Deleting a node
  1. parentNode.removeChild(node),parentNode.romve(node)
  • Changing a node
  1. Class: node.classlist.add (), node.className = “”
  2. Modify style:node.style.color = “”
  3. Change: node.innerText =”
  4. Modify properties: Node.setatrribute (), node.getatrribute ()
  5. Node.onclick = function(){}

3. Virtual DOM in vue and React

3.1 Definition: Objects that can represent DOM, including tag names, attributes, child nodes, event listeners, etc

3.2 the dom structure

  • The react virtual DOM data structure looks like this

  •   const vNode = {
       key:xxx,
       type:'div',
       ref:xxx
       prop:{
        className:xxx,
        onClick:()=>{}
        children:[
          {type:p,....},
          {type:span,...}
        ]
       }
      }
    Copy the code
  • The virtual DOM data structure in vUE is shown below

  •   const vNode = {
          tag:'div',
          data:{
          class:'red',
          on:{
           click(){}
          }
         },
          children:[
          {tag:p,....},
          {tag:span,...}
          ]
      }
    Copy the code

3.3 How to Create a Virtual DOM

  • Vue goes through h

    h(‘div’,{ class:’red’, on:{ click:()=>{} }},[h(‘p’,{},’span’),h(‘p’,{},’span’)])

  • React uses the createElement() function

    CreateElement method (‘ div ‘{className:’ red, onClick () = > {}, [createElement method (‘ p ‘{} / / attributes, “span”), CreateElement (‘p’,{// attribute},’sapn’)]})

3.4 Benefits of the virtual DOM

  • To reduce the number of DOM operations, the virtual DOM stores the elements to be created in the array, and then inserts them into the node once again. Meanwhile, dom diff is used to compare dom changes layer by layer to obtain patch and then update DOM.
  • Cross-platform support