Re: [RFC] [Vote] New ext-dom features in PHP 8.4
On 20/06/2024 23:55, Matthew Weier O'Phinney wrote:
>
>
> On Thu, Jun 20, 2024, 1:27 PM Niels Dossche <[email protected] <mailto:[email protected]>> wrote:
>
> On 20/06/2024 16:28, Matthew Weier O'Phinney wrote:
> >
> >
> > On Mon, Jun 10, 2024 at 1:15 PM Niels Dossche <[email protected] <mailto:[email protected]> <mailto:[email protected] <mailto:[email protected]>>> wrote:
> >
> > Hi internals
> >
> > I'm opening the vote of my RFC "New ext-dom features in PHP
> >8.4".
> > RFC link: https://wiki.php.net/rfc/dom_additions_84
> ><https://wiki.php.net/rfc/dom_additions_84>
> ><https://wiki.php.net/rfc/dom_additions_84
> ><https://wiki.php.net/rfc/dom_additions_84>>
> > Voting runs until 24th of June 21:00 GMT+2.
> >
> > Kind regards
> > Niels
> >
> >
> > Question: why is Dom\Document::$head
marked as readonly?
>
> The HTML spec defines the head property to be readonly: https://html.spec.whatwg.org/#document <https://html.spec.whatwg.org/#document>
> That's why $head is marked readonly.
>
> So I guess the question becomes "why does the HTML spec define it this way?"
> I couldn't find a conclusive answer to this, it looks like this has been read-only
> since HTML's early days...
> I thought about it but don't really see a technical reason why this is the case. If I
> had to take a guess I'd say it's for simplicity sake.
> > he/him
>
>
> I can understand that from a browser perspective, but from PHP, where we might be manipulating
> HTML to send back to the client, having it readonly would be a pretty big hindrance.
>
Would it?
Note that only the binding is readonly, you can manipulate the head element as you wish.
e.g. $doc->head->replaceWith($another_element);
is still possible and not much
more difficult than $doc->head = $another_element;
.
I could add a setter for the head element, but what if WHATWG defines a setter for the head element
at a later point in time that's incompatible with what I added?
It may sound far-fetched, but that's not unreasonable given that setting the $body property is
way more complicated than just find+replace <body>
(e.g. handles framesets too).
Kind regards
Niels
Thread (6 messages)