dom range.setStart / setEnd

后端 未结 2 2066
深忆病人
深忆病人 2021-02-20 17:52

I am trying to bold only the text hel in this fiddle http://jsfiddle.net/yarkpakv/ but it does not seem to be working, what am I doing wrong???

相关标签:
2条回答
  • 2021-02-20 18:15

    Got it ...

    var range = document.createRange();
    var root_node = document.getElementById("test");
    
    range.setStart(root_node.firstChild,0);
    range.setEnd(root_node.firstChild,3);
    
    var newNode = document.createElement("b");
    
    range.surroundContents(newNode);
    

    In all of the documentation, they are referencing the "Child" ... this solves that. In the case of your Fiddle, it will wrap the Letter "h" and the two <p> and </p> tags. Take them out and hel becomes bold.

    UPDATE:

    Apparently, whitespace will cause problems ...

    HTML ...

    TEST

    Working here ... jsFiddle

    Reference ... HERE

    0 讨论(0)
  • 2021-02-20 18:20

    You need to visualize the DOM structure of your <div id="test"> element. It contains three children:

    1. A text node that contains only white space.

    2. The <p> element which contains a text node that has the value h.

    3. A text node that has the value ello.

    So your range must start with the <p> element and ends in the ello text node, between the two l characters. Therefore:

    var range = document.createRange();
    var root_node = document.getElementById("test");
    
    // Start at the `<p>` element.
    range.setStart(root_node, 1); 
    
    // End in the `ello` text node, between the two `l`s.
    range.setEnd(root_node.childNodes[2], 2); 
    
    var newNode = document.createElement("b");
    
    range.surroundContents(newNode);
    

    Here's a fiddle.

    0 讨论(0)
提交回复
热议问题