#725: Early design review for Range API improvements
Discussions
Discussed
 Apr 18, 2022  (See Github)
  Question if innerText causes style calc/reflow like Node.innerText does, if so maybe better served by an async method?
We have quesitons abou how innerText maps to the range when adjustments are made, e.g. if an end point is in a hidden node, and the enpoint is moved, does it move to the start/end of the hidden text + offset?
 Comment by @cynthia  Apr 19, 2022  (See Github)
  We looked at this during a breakout today - here are some questions.
- innerText will trigger synchronous layout. This is not something we advocate new APIs doing; this should be made into an async API. (Probably not named innerText, since one being a property and this specific case being a method would be incredibly confusing.)
- Range.innerText and DOM do not directly map well; how would the mappings work when a hidden (e.g. via-CSS) node is involved?
 Comment by @dlibby-  May 26, 2022  (See Github)
  Thanks for your response. I'm curious around prior art on APIs not triggering synchronous layout? In general, I think primitives such as ResizeObserver and IntersectionObserver make sense to have a specific observable spot during the 'update the rendering' steps to trigger observations - these are intrinsically tied to the state of the page that will (soon) be visible to the user.
For something like the innerText of a Range, it's unclear to me when authors could expect the callback to be invoked (i.e. what happens if there are subsequent DOM mutations, etc.). So I don't think this API is the best place to try to define those semantics, unless perhaps you're arguing something like a RangeObserver would be a better pattern? I could also see that being a bit confusing to authors (updates to the Range itself are synchronous) and add non-trivial overhead.
Also, I'd note that the adjust() method would be ergonomically difficult for authors to use if it also is async (it will rely on up-to-date layout data structures). One of the use cases, is to move ranges in conjunction with, e.g. Intl's word breaker, splitting multiple moves even across microtasks when other mutations may be interleaved seems like it would be difficult to reason about and achieve consistent results.
Please let me know if you had anything more specific in mind in terms of not having synchronous layout.
Range.innerText for hidden nodes would work the same as Element.innerText. Namely we'd run the steps from https://html.spec.whatwg.org/multipage/dom.html#the-innertext-idl-attribute but instead of an element and subtree, it would just span the range instead. So if the Range started in a part of the tree that was visibility:hidden, that text wouldn't be output (until walking through the range encountered an element that was visible).
Discussed
 Jun 20, 2022  (See Github)
  Lea: Reasonable question.. prior art..
Dan: lets punt to plenary but also maybe for B.
Discussed
 Jul 18, 2022  (See Github)
  Sangwhan [via chat]: I don't understand OP's comment.
Lea: will ask Sangwhan to comment on the issue.
Discussed
 Aug 8, 2022  (See Github)
  Peter: My biggest concern - on the innertext and hidden stuff it's just that it was under-specified... my biggest concern was that sync ... they're pushing back on that...
... they have an answer on the other issue.
... sync forces a style computation.
... several times we've raised this... the prior art is broken. Not much if any lot of prior art doing it the wrong way. we'd like to fix this...
Tess: did Range.innerText not exist before? I understand the temptation.. but why propogate a [antipattern]?
Rossen: are you proposing to keep this from progressing until they figure out async?
... pushing for something - from expected behaviour and pattern - makes sense - but doesn't exist anywhere... we don't have good guidance.. we reviewed the event loop at the f2f - my expectation from the TAG pov - solid guidance - this is what causes flushes, this is what causes batches... this doesn't exist. Brings us.. we can continue to ask and be ignored or ... no alternative.
Tess: I think the alternative ... TAG vigilence... not suggesging we do the rigorous def.
Peter: we could guuide people to look at a better alternative...
Rossen: I think we can engage in a more meaningful way.
Peter: they can make it async.. they can turn it into an observer... there are paths forward... there's the issue of "leave it better than you found it" - just because someone else made the mistake before ...
Rossen: we're not steering them on how to move from the sync API...
Lea: we don't have a design principle don't trigger synchronous layout?
we look back through the design principles
Dan: open a design principle issue and get some debate going in the design principle?
Peter: What should our feedback be?
Rossen: i will open the issue
Peter: I will take a stab at writing the feedback...
<blockquote>@dlibby unfortunately there's not a lot of prior art of code not triggering synchronous layout and style computation. But this is something we're trying to fix. Existing cases tend to be bad for user experience and overall performance. We do have a general principle about not using the existence of less than ideal designs as license to repeat the mistake.
We understand that making the proposed adjust() method async raises further complications, but we would like to invite your group to discuss our concern and offer possible alternatives.
We've also opened a new issue about the general problem of synchronous layout and style and welcome your group's input there.
</blockquote> Comment by @plinss  Aug 11, 2022  (See Github)
  @dlibby unfortunately there's not a lot of prior art of code not triggering synchronous layout and style computation. But this is something we're trying to fix. Existing cases tend to be bad for user experience and overall performance. We do have a general principle about not using the existence of less than ideal designs as license to repeat the mistake.
We understand that making the proposed adjust() method async raises further complications, but we would like to invite your group to discuss our concern and offer possible alternatives.
We've also opened a new issue about the general problem of synchronous layout and style and welcome your group's input there.
Discussed
 Aug 29, 2022  (See Github)
  Peter: waiting for response - async vs sync
Discussed
 Nov 14, 2022  (See Github)
  Lea: still pending external feedback since august? This is another review pushing for synchronous layout stuff.
Peter: pushing off into Houdini land.. what do we do to help get to the state of this becoming async?
Lea: [drafts comment asking for updates]
Peter: I'd like to see evidence that they're discussing making this async in the WG
 Comment by @LeaVerou  Nov 14, 2022  (See Github)
  Hi @dlibby-, we are considering closing this, should we leave it open? Are there any updates for us?
 Comment by @plinss  Feb 7, 2023  (See Github)
  Since we haven't gotten any response in a while we're going to close this issue for now. We're also waiting for other work on the sync vs async style/layout flushing issue. Feel free to ping us to reopen this if there's any updates on your end.
OpenedMar 23, 2022 
Braw mornin' TAG!
I'm requesting a TAG review of Range API improvements for rendered text content.
Ranges are somewhat limited in capabilities for advanced editing scenarios. While Ranges expose information about the rendering of the contained text via client rect(s), they only expose the text content (not the visible text — see differences) of the Range to script via toString(). Without this information, web developers resort to heuristics in JavaScript to map offsets of the visible text back to Node offsets in the DOM, which can be computationally expensive and error prone. This proposal aims to expose a flat text representation of the rendered text of a Range objects and allow developers to move a Range's endpoints over that representation, while keeping the Range rooted in DOM positions.
Further details:
We'd prefer the TAG provide feedback as (please delete all but the desired option):
💬 leave review feedback as a comment in this issue and @-notify [dlibby-]