Show HN: JavaScript-free (X)HTML Includes

(github.com)

204 points | by Evidlo a day ago ago

106 comments

  • tannhaeuser 16 hours ago

    This is how the simplest variant of SGML (or XML) entities have worked since 1986:

        <!doctype html [
          <!entity e system "e.html">
        ]>
        <html>
          <title>Hello, world!</title>
          <p>The content of e is: &e;</p>
        </html>
    
    HTML was envisioned as an SGML vocabulary from day one. That SGML's document composition and other facilities were used only at authoring time and not directly supported by browsers was merely due to the very early stage of the first browser software ([1]) which directly mentions SGML even, just as HTML specs have presented HTML as a language for authoring and not just delivery since at least version 4.

    There really never had been a need or call for browser devs to come up with idiosyncratic and overcomplicated solutions relying on JavaScript for such a simple and uncontroversial facility as a text macro which was part of every document/markup language in existance since the 1960s.

    [1]: https://info.cern.ch/hypertext/WWW/MarkUp/MarkUp.html

    • the_mitsuhiko 12 hours ago

      > This is how the simplest variant of SGML (or XML) entities have worked since 1986:

      In theory. In practice not a single browser had an actual SGML parser and that was never supported.

    • bawolff 7 hours ago

      Entities are also probably a significant reason for XML's bad reputation. Between using them to leak senditive files (XXE), and recursive expansion being a DoS vector (million laughs), it cemented XML's reputation as a security risk.

      In the browser context though, i don't see why they couldn't just follow same origin rules.

      • tannhaeuser 6 hours ago

        I was surprised this wasn't brought up earlier, as it always is in these discussions. It's trivial to mitigate security risk arising out the use of entities. SGML even has the CAPACITY ENTLVL built-in entity nesting limit.

        TBH, a browser has one million other potential leaks and exploits and denials to care about. Unlike a markup language with carefully crafted rules about what to expand in which context, a browser providing a Turing-complete language trivially runs into infinite loops or recursion and could at best heuristically terminate JS code, after using laborious best-efforts methods such as execution traces and watchdog timers. Moreover, JS syntax itself and how it's represented in markup unneccessarily gives rise to obfuscation and escaping attacks. And the browser in addition also plays fast and loose with an ever-expanding, potentially Turing-complete styling language with super complicated styling syntax and constraint-based layout models with a complete lack of formal semantics or any other formal reasoning. CSS itself can contain HTML literals at several places such as data URIs and the content property with questionable escaping, but I guess this is par for the course when CSS is basically just tunneling yet another syntax through HTML attributes and elements. Context Security Policy is just bolted on to limit this pointless and careless gratuitious syntax proliferation, and of course must invent its own little item-value microsyntax to be tunneled through HTTP headers and HTML header tags.

        Considering these glaring and obvious deficits weren't discussed at the same time I assume those who brought up XXE and suggested SGML/XML could leak documents or smuggle executable instructions did so in bad faith or were repeating hearsay to sound clever or something.

        • bawolff 5 hours ago

          This is mostly not an issue in browsers so much as non browser implementations. Its not even really an issue in modern implementations with better defaults.

          What it did do is create a perception that XML is insecure. This hastened its demise.

          > It's trivial to mitigate security risk arising out the use of entities.

          Obviously. However in practise, historically most implementations did not. At least not by default.

          XML spec bears some responsibility for this for not being explicit about suggesting secure defaults.

          Regardless, JSON won partially because it didnt have the attack surface, so people didn't have to worry. XML being theoretically easy to secure means nothing when practically implementations made it difficult.

    • myfonj 14 hours ago

      I wish external entities were enabled in browsers (*), and not entirely disabled, like they are now.

      In the OP scenario, it would provide possibility to have header/footer/stylesheet content in separate files and get system working that does not rely on absolute path of the CSS.

      (*) Naturally, just with few minimal directory traversal precautions; basically anything like "no ../" and even restriction like "referenced resource filename must begin with referencing XSL filename" would be fine for me.

    • DonHopkins 13 hours ago

      XULRunner (Firefox, Thunderbird, Songbird, Miro, Joost, TomTom Home, etc) abused XML external entities in language specific DTDs for internationalization / localization.

      https://www-archive.mozilla.org/projects/intl/iuc15/paper/iu...

      https://en.wikipedia.org/wiki/XULRunner

  • bawolff 21 hours ago

    Since this seems to be about the recent proposal to remove xslt, i'd point out you can do the same thing with CSS

    https://bawolff.net/css-website/index.xml is Evidlo's example but using a css stylesheet instead of xslt. I changed some of the text to explain what i was doing, but otherwise the XML is unchanged with one exception. Unfortunately you do have to put the <a> tags in the xhtml namespace to make them clickable. Other than that no changes to the xml.

    Obviously there is a lot that xslt can do that css cannot, but when it comes to just display, CSS is an option here.

    • egeozcan 17 hours ago

      This is really, definitely cool, but it's important to remember that content added via CSS is purely decorative. It can't be interacted with, which is a major issue for assistive technologies like screen readers.

    • 8organicbits 20 hours ago

      > there is a lot that xslt can do that css cannot

      This latter part is why I've reached for XSLT in the past. Most recently was to convert an RSS feed into a styled page with instructions at the top. Templates and xpath can really transform a document.

    • Evidlo 17 hours ago

      Thanks for the CSS example.

      By the way, the advanced/ folder has a slightly more complicated example that demonstrates template inheritance and "slots".

      • bawolff 16 hours ago

        Yeah, i saw. Unfortunately the advanced example wouldn't be doable in CSS. I suppose i'm being a bit intellectually dishonest to not explicitly point that out.

    • em-bee 13 hours ago

      that feels a bit to simplified. i'd like to see an example that includes at least some html, and maybe clickable links. it's maybe also worth showing that you can include images with css.

    • lenkite 17 hours ago

      Umm..your CSS example doesn't show any template includes. No way to put header/footer in separate files.

      • em-bee 13 hours ago

        but they are in a separate file. the css file. you an load multiple css files if you want to break it out.

      • bawolff 16 hours ago

        The original example didn't have that either.

    • Pxtl 17 hours ago

      > i'd point out you can do the same thing with CSS

      Cool when are they removing CSS from the standard?

  • xnx a day ago

    Why didn't HTML imports stick around? https://web.dev/articles/imports

    • lloydatkinson 21 hours ago

      The moronic Web Component cabal got their hands on it and trashed it by forcing it to rely on JavaScript, thus ensuring it would never get support.

      • spankalee 17 hours ago

        I'm sorry, this a dumb comment that has no basis in reality.

        HTML Imports was part of the initial set of the web components specs, there's no "cabal" or whatever that got its hands on it, and it didn't rely on JavaScript, not in the way you're probably referring to.

        It was only opposed because it was separate from the JS module system, not because it relied on JS.

        It's replacement: The HTML Modules proposal has general support from all vendors, just no one has put together a complete proposal yet.

        • MortyWaves 15 hours ago

          It was rejected because it needed JS to even work.

          • spankalee 15 hours ago

            This is simply not true, both in how it worked and why it was rejected.

            HTML Imports didn't need JS to work: they used link tags and could transitively import HTML files without any JS.

            You only needed JS because the wasn't anything you could do with the HTML yet because declarative custom elements don't exist yet.

            HTML Imports were rejected because they created a parallel module graph to the JS module graph.

            I think they could have been made to share the same graph, but that's basically what HTML modules are anyway.

      • abraham 21 hours ago

        For a long time web components generally built on four standards:

          - Custom HTML elements
          - Shadow DOM
          - HTML imports
          - HTML templates
        
        https://korban.net/posts/elm/2018-09-17-introduction-custom-...

        Eventually it became clear some browsers were not going to implement and the design of HTML imports was better handled be ES modules.

        https://webmasters.stackexchange.com/questions/127482/on-wha...

      • bapak 20 hours ago

        Found this, it should answer your complaints:

        > HTML Imports were redundant, since you need JavaScript to bring them alive anyways

        • thayne 19 hours ago

          Exactly. I think the problem wasn't that browsers (specifically Firefox and Safari) were opposed to the idea of html includes in general, but they didn't like the specific proposal, in large part because it still required javascript, and added a lot of complexity for little to no benefit.

          I think rejecting that proposal was the right thing to do. What disappoints me is that there hasn't been a more declaritive, simpler proposal that has gotten anywhere.

          • spankalee 17 hours ago

            HTML Imports and HTML includes are two different ideas. HTML Imports was never like what people want from HTML includes.

            HTML Imports were shelved because they didn't integrate with the JS module graph. HTML Modules will do that someday.

          • xnx 18 hours ago

            > What disappoints me is that there hasn't been a more declaritive, simpler proposal that has gotten anywhere.

            Possible names: Client Side Includes (CSI): Like Server Side Includes (SSI) in Apache IHTML (inline html): Like the iframe tag, but for html instead of whole page.

  • shakna a day ago

    As of the next version of Chrome, XSLT will be gated behind a flag.

    Google have also asked for it to be removed from the standard [0].

    [0] https://github.com/WHATWG/html/issues/11523

    • chrismorgan a day ago

      > As of the next version of Chrome, XSLT will be gated behind a flag.

      Citation? That would greatly surprise me in its abruptness and severity (they only just started talking about it this month, and acknowledge it’s particularly risky for enterprise) and https://chromestatus.com/feature/4709671889534976 gives no such indication.

      • shakna 21 hours ago

        The meeting referenced there, from March not last month, also gives no indication that they'd go ahead and make any moves - "stick a pin in it". But they did anyway. [0]

        panos: next item, removing XSLT. There are usage numbers.

        stephen: I have concerns. I kept this up to date historically for Chromium, and I don't trust the use counters based on my experience. Total usage might be higher.

        dan: even if the data were accurate, not enough zeros for the usage to be low enough.

        mason: is XSLT supported officially?

        simon: supported

        mason: maybe we could just mark it deprecated in the spec, to make the statement that we're not actively working on it.

        brian: we could do that on MDN too. This would be the first time we have something baseline widely available that we've marked as removed.

        dan: maybe we could offer helpful pointers to alternatives that are better, and why they're better.

        panos: maybe a question for olli. But I like brian's suggestion to mark it in all the places.

        dan: it won't go far unless developers know what to use instead.

        brian: talk about it in those terms also. Would anyone want to come on the podcast and talk about it? I'm guessing people will have objections.

        emilio: we have a history of security bugs, etc.

        stephen: yeah that was a big deal

        mason: yeah we get bugs about it and have to basically ignore them, which sucks

        brian: people do use it and some like it

        panos: put a pin in it, and talk with olli next time?

        panos: next thing is file upload control rendering

        [0] https://github.com/whatwg/html/issues/11146#issuecomment-275...

        • magicalist 20 hours ago

          > But they did anyway.

          Did what? The GP asked for a citation for XSLT support going behind a flag in the next version of Chrome, but you forgot to add that. As best as I can tell, the GP is right and you're confused.

          • troupo 14 hours ago

            Tracking issue: https://issues.chromium.org/issues/435623334

            Add flag to disable XSLT: https://chromium-review.googlesource.com/c/chromium/src/+/68...

            It's approved, I don't know which release it will be.

            Additionally, quote from the GitHub discussion:

            --- start quote ---

            Q: why has Chrome already started working on removing the feature from the browser?

            A: To explore the effects of removal. It's hard to tell what will break without being able to turn it off and see.

            https://github.com/whatwg/html/issues/11582#issuecomment-320...

            --- end quote ---

            • afavour 13 hours ago

              > The GP asked for a citation for XSLT support going behind a flag in the next version of Chrome

              > Add flag to disable XSLT

              Two very different things. OP is talking about XSLT support going behind a flag, you’re citing XSLT deprecation going behind a flag. The default state matters (and the default state is undeprecated)

              It makes sense that the Chrome team would do what they’re doing, otherwise it’s very difficult for anyone to assess the impact of XSLT deprecation.

              • chrismorgan 7 hours ago

                I’d reword that: Google haven’t deprecated it (yet), they’ve added a flag whereby you can disable it (which, at this stage, is only being used by a test).

                “Deprecate” has a specific meaning, largely unrelated to actual removal (though depending on the convention it may be expected to lead to it after some time).

              • troupo 12 hours ago

                > OP is talking about XSLT support going behind a flag, you’re citing XSLT deprecation going behind a flag.

                Literally from my link:

                --- start quote ---

                Add a feature flag to disable XSLT

                This adds a feature flag that disables:

                - XSLTProcessor

                - XSLT Processing Instructions

                --- end quote ---

                • afavour 11 hours ago

                  Literally from my comment:

                  > The default state matters (and the default state is undeprecated)

                  OP said “ But they did anyway”, and they did not

        • chrismorgan 20 hours ago

          By “started talking about it this month” I meant this specific advocation for removing it. Yes, it’s been talked about for years, but this time it’s specific.

          • shakna 19 hours ago

            > brian: we could do that on MDN too. This would be the first time we have something baseline widely available that we've marked as removed.

            They were advocating for removing it. And it was specific. And is labelled by the Chromium report you mentioned as the cause.

            It wasn't "this month".

            • chrismorgan 17 hours ago

              Again, that’s prior discussion. It’s happened a few times over the last few years.

              Then another few months pass, and one of the agitators goes about formally proposing removing it, so that finally it isn’t just murmurings more or less behind closed doors, but out in public for the developers to clamour about. That’s where we are this month.

              • shakna 12 hours ago

                Again, that prior discussion that you're dismissing as irrelevant - is the discussion the Chromium report links to! I don't think that can really get more definitive as cause and effect.

                • chrismorgan 6 hours ago

                  I’m not calling it irrelevant, just not part of the actual proposal and ensuing furore, which began this month. We discover there have been mutterings of this for years, and certainly those things led up to it, but this was the first public intimation. They don’t ever say “hi public, we know this is the first you’ve heard about it, but we’re removing a major feature next month”, which is basically what you were claiming (or what it amounted to). Far simpler and less controversial changes have taken many months to be shipped.

    • simpaticoder a day ago

      It's kind of too bad XSLT didn't take off. It is quite complex, until you compare it to the complexity of what now solves this problem (e.g. a build step with React and webpack and javascript absolutely required on the client-side). As the OP ably demonstrates, XSLT provides a declarative, non-javascript, non-build way to solve the basic HTML component problem. Perhaps a devastating 0-day in V8 will make us really, really want an alternative to the current best practice.

      • shakna a day ago

        Whilst I can't be certain, I've been hearing that part of Google's want to move away from XSLT is two-fold - and relates to the idea of the security problem.

        Partly, there's increasing attacks against XML.

        And also, libxml2 has said "no" to security embargoes altogether. [0]

        They might well consider there to be 0-days waiting in XSLT.

        [0] https://news.ycombinator.com/item?id=44381093

      • MrJohz 18 hours ago

        I think the big difference there is that browsers are only responsible for Javascript, which is a big general purpose solution that solves a lot of problems and not just templating/styling XML. Everything else either happens server-side (build steps and webpack) or is userland code that lives inside the sandbox. So there's one task for browsers to do (make a fast and secure Javascript sandbox), and if that works that developers can do whatever they want. Whereas XSLT is not a general purpose tool in the same way, and so needs to be maintained in addition to Javascript and anything else that exists.

        If course XSLT can also be used server-side (which is probably a good idea if you want access to the latest features and not some ancient, frozen version of the spec), but browsers aren't the reason that that didn't take off. My guess there is that it's just not an intuitive way of manipulating and templating data in comparison to more traditional HTML templating libraries.

      • AgentME 20 hours ago

        React supports rendering to HTML ahead of time (SSR) which doesn't need any client-side javascript, and this is a prominent feature of most frameworks using React. This feature of React was one of its major innovations over many other front-end frameworks of the time.

        • degamad 17 hours ago

          > React supports rendering to HTML ahead of time (SSR)...

          So does XSLT?

          • throwaway290 14 hours ago

            Literally not one person said XSLT can't do it. But in case you missed it somebody did said React can't do it and so XSLT is better.

            > build step with React and webpack and javascript absolutely required on the client-side

            This was a false statement.

            both XSLT and React can be used for this except React can additionally do a bunch of other stuff that does use JS and that XSLT can't do.

      • bawolff 18 hours ago

        I don't think react is comparable.

        React's main thinh is client side reactivity, something that xslt doesn't offer.

        A closer comparison would be a templating engine that does statuc conversion to html.

    • notpushkin a day ago

      Yeah, I think that was what prompted this submission.

      All this has also reignited my idea for a compile-to-XSLT templating language, too – maybe I’ll get to it finally this time; definitely if XSLT 3.0 gets into web standards: https://github.com/whatwg/html/issues/11578, https://news.ycombinator.com/item?id=44987552

      Also, I’ve put together a simple XSLT playgroung a while ago! https://xsltbin.ale.sh/

    • SnuffBox a day ago

      I find it bizarre that Google can just ask for a feature to be removed from standard and nobody bats an eye.

      • johncolanduoni 21 hours ago

        To be fair, some things should be legitimately considered to be removed from the standard. O.G. XHTML basically mandated that you accept XML logic bombs and we got over that.

        Also, while this is certainly Google throwing their weight around, I don’t think they are doing it for monetary advantage. I’m not sure how removing XSLT burnishes their ad empire the way things like nerfing ManifestV3 have. I think their stated reasons - that libxslt is a security disaster zone for an obscure 90s-era feature - is earnest even if its not actually in the broader web’s best interests. Now that Safari is publicly on board to go second, I suspect it’s an inevitability.

        • Mikhail_Edoshin 16 hours ago

          XML "logic bombs" happens when the parser expand entities eagerly. If a parser does that one can easily assemble an enormous entity that will eat up all the memory. But a more sophisticated parser won't expand entities right away and thus can merely reject oversized ones. It is really a minor issue.

          • johncolanduoni 2 hours ago

            There were other esoteric XML logic bomb inducing features is my recollection from all the stuff you used to have to change on the default XML Java parsers, but this was like 20 years ago so I may be misremembering.

      • notpushkin a day ago

        If I understand correctly, Mozilla and Apple don’t really want to support it either. And the reason for that is, the spec is still at XSLT 1.0, which is super old, and current implementations are effectively abandonware. Catch-22?

        • johncolanduoni 21 hours ago

          I believe the spec is at XSLT 3.0 but no browser actually implemented past XSLT 1.0 (not 100% sure - almost nobody cared about this feature last month so hard to find good docs on support). HTML5 and C++ are cut from the same cloth - massive and no reference implementation so full of features that have been “standard” for 10 years but never implemented by anyone.

          • notpushkin 20 hours ago

            Yeah, sorry, the XSLT spec is at 3.0 right now of course, but the browsers don’t implement it, and the WHATWG HTML Living Standard only mentions XSLT 1.0.

          • arccy 20 hours ago

            even outside of browsers barely anything supports XSLT newer than 1.0

        • ekianjo 21 hours ago

          The spec is at XLST 3 right now.

      • esrauch a day ago

        It doesn't seem weird at all to me: standard is essentially the consensus of the major browser vendors; a spec which all of Chrome, Safari and Edge don't implement is really just a hypothetical.

        The origin story of whatwg is that Apple, Mozilla and Opera decided that W3C wasn't making specs that they wanted to implement, so they created a new working group to make them.

      • chrismorgan 21 hours ago

        > nobody bats an eye

        I’ve seen a lot of eye-batting about this. Although Google, Mozilla and Apple are all in favour of removing it, there’s been a lot of backlash from developers.

        • johncolanduoni 20 hours ago

          Most of whom had never heard of XSLT before today - some were likely born after it had faded into obscurity. I don’t blame people for hating Google for whatever reason, but this is a weird way to try to stick it to them.

          • sunaookami 13 hours ago

            XSLT is widely used, for example by the US congress: https://simonwillison.net/2025/Aug/19/xslt/

            • lucumo 10 hours ago

              Neither you nor the blog posts author had heard of that before that ridiculous GitHub issue from yesterday. You're all using the exact same link to the exact same page. This is intellectual dishonesty from you, the blog post author and the issue reporter.

              Anyone who has read the response to the reporter knows that this is a cherry-picked alternative format. The normal format is an HTML5 page. Search engines just return that instead, so the only way to have found this page is by clicking through that.

              • sunaookami 10 hours ago

                So "it doesn't matter because other people already posted this example"?

                • johncolanduoni 2 hours ago

                  I think their point was that for everything the US congress makes available through client-rendered XSLT, they already also do the transformation on their side and serve the HTML under another page. Which I think is part of Google’s point - you can just compile the XSLT offline once (or during your release process) and provide the same experience without rewriting anything.

                • lucumo 5 hours ago

                  Is your intellectual dishonesty professional, or just a hobby?

          • ndriscoll 12 hours ago

            More likely the people complaining are those who use it. I've been using it as the sane way to template my personal stuff for ~20 years. It works very well for "hand written" sites. I'm also not trying to be a top site or even visible to the wider world; my audience is my friends and family members. So to me it's a clear "that's not an important use case for the web now" signal.

      • TiredOfLife 12 hours ago

        Mozilla asked for removal. Google just filled the paperwork

      • ekianjo 21 hours ago

        Even "champion of the web" Mozilla is on board. Tells you exactly what you need to know.

    • kome a day ago

      so it's time to use XSLT more

  • Kuyawa 7 hours ago

    20 years ago I saw the greatness of xml and xslt as I was coming from the painful inferno of an EDI shop. There is nothing more beautiful than sending plain data to a client and being able to see the whole document without any extra bloating, that's what XSLT was intended for:

      <?xml version="1.0"?>
      <?xml-stylesheet type="text/xsl" href="/invoice.xsl"?>
      <invoice>
        <date>2025-08-23</date>
        <customer>
          <name>John Doe</name>
          <address>
            <line>123 Sunny Boulevard</line>
            <city>Miami</city>
            <state>FL</state>
            <zip>33133</zip>
          </address>
        </customer>
        <items>
          <item>
            <code>123456</code>
            <description>Some Apple gadget</description>
            <quantity>1</quantity>
            <price>1234.56</price>
            <total>1234.56</total>
          </item>
          <item>more items...</item>
        </items>
      </invoice>
    
    That piece of data would be sent to millions of customers and they could open it and the XML was transformed in an invoice perfectly formatted for human consumption. Both flesh and silicon were living happy in perfect harmony.

    Then it came SOAP and all the corporate suits and messed it all up into an extra complicated bloatness of anguish and suffering, but XML/XSLT were beautiful on their own (for data transformation, not web pages)

    • Kuyawa 6 hours ago

      If we extrapolate it all to JSON, all we need to do is add two lines to the data file to reference the JSLT source and then use any templating system as default (ejs, mustache, handlebars) to do the transformation in the browser

        {
          "JSLT": "1.0",
          "style": "/invoice.jsl",
          "data": {
            "invoice":{
              "date": "2025-08-23",
              "customer": {
                "name": "John Doe",
                "address": {
                  "line": "123 Sunny Boulevard",
                  "city": "Miami",
                  "state": "FL",
                  "zip": "33133",
                },
              },
              "items": [
                {
                  "code": "123456",
                  "description": "Some Apple gadget",
                  "quantity": "1",
                  "price": "1234.56",
                  "total": "1234.56",
                },
                {
                  "code": "123457",
                  "description": "Another Apple gadget",
                  "quantity": "1",
                  "price": "1234.57",
                  "total": "1234.57",
                }
              ]
            }
          }
        }
      
      Then the JSLT file:

        <html>
        <body>
          <h2>Invoice</h2>
          <p><label>Date</label> <span><%=data.invoice.date%></span></p>
          <div>
            <h3>Customer</h3>
            <p><%=data.invoice.customer.name%></p>
            <p>
              <%=data.invoice.customer.address.line%>
              <%=data.invoice.customer.address.city%>
              <%=data.invoice.customer.address.state%>
              <%=data.invoice.customer.address.zip%>
            </p>
          </div>
          <table>
            <tr>
              <th>Code</th>
              <th>Description</th>
              <th>Quantity</th>
              <th>Price</th>
              <th>Total</th>
            </tr>
            <% for(item of invoice.items) { %>
              <tr>
                <td><%=item.code%></td>
                <td><%=item.description%></td>
                <td><%=item.quantity%></td>
                <td><%=item.price%></td>
                <td><%=item.total%></td>
              </tr>
            <% } %>
          </table>
        </body>
        </html>
      
      Then we could get rid of XSLT
  • ulrischa 17 hours ago

    To overcome the two problems here (client side loading the template and ending browser support) you could throw in php in the mix and have a wonderful solution for templating with bullet proof standards: // XML $xml_doc = new DOMDocument(); $xml_doc->load("file1.xml");

    // XSL $xsl_doc = new DOMDocument(); $xsl_doc->load("file.xsl");

    // Proc $proc = new XSLTProcessor(); $proc->importStylesheet($xsl_doc); $newdom = $proc->transformToDoc($xml_doc);

    // Output print $newdom->saveXML();

    XSLT lacks functionality? No problem, use php functions in xslt: https://www.php.net/manual/en/class.xsltprocessor.php

    • Telemakhos 7 hours ago

      What you're describing is basically Symphony, the CMS built around XSLT with some PHP and MySQL to glue things together: https://github.com/symphonycms/symphonycms

      I don't think it's been updated since 2019. XSL was really powerful, but it had a steep learning curve, and I think server-side PHP and client-side JS were just more intuitive.

      • ulrischa 5 hours ago

        Cool project. Sadly it seems to be unmaintained

  • mgr86 19 hours ago

    A small comment for anyone new to xslt. The author references a wildcard rule in the comments [0]. While that is true, they are calling an identity transformation [1]. Identity transformations are very common in xslt.

    [0] https://github.com/Evidlo/xsl-website/blob/0dda1d82ce1eb01b7... [1] https://en.wikipedia.org/wiki/Identity_transform

  • raggi a day ago

    I used to do this in the 2000's era, there was a lot to love about it. At the time though the IE engines were far more complete and less buggy than others with various XML features.

  • basscomm a day ago

    Looks promising!

    This looks like as good a place as any to show the XML/XSLT code that I've been tinkering with for the last couple of years: https://github.com/zmodemorg/wyrm.org

  • b_e_n_t_o_n a day ago

    This works client side right? So when a user navigates to this page, it recursively fetches content from the server? And if you have nested includes it would waterfall?

    Even single page app frameworks have mostly solved this by doing the rendering on the server instead of making multiple round trips from the client. This feels like the no-JavaScript version of Spinnergeddon.

    Does the browser wait for all the includes to resolve before showing the page or does it flicker in?

    • dweinus 21 hours ago

      If you want server-side compilation, you could just run the xslt transform in ci/cd. It would still be a simpler solution than Jekyll in some regards, but I probably wouldn't do it for more than hobby projects

    • bawolff a day ago

      Looking at the xslt stylesheet , it doesn't look like there are nested includes, its just one stylesheet which doesn't include anything else. So its not that different in terms of requests than how css would work.

      • magicalist 20 hours ago

        > Looking at the xslt stylesheet , it doesn't look like there are nested includes, its just one stylesheet which doesn't include anything else

        At least the browser has to load template.xsl before it can know it has to load the css file though, right? And this is just a simple demo page.

        • bawolff 16 hours ago

          I guess its ine extra layer, but its not like we've gone 14 layers deep or something.

          I imagine preloading the css file using the http link header would solve this problem.

        • b_e_n_t_o_n 18 hours ago

          It's making three round trips. The first is to get the original xml file, then it's to load the second xml file, then it's to load the stylesheet.

          Now you can imagine with a real site, you will have many includes per page, each one perhaps using includes of it's own. You end up with a really bad waterfall where it can take a long time for a page to load because it's going back to the server constantly, whereas if you did it on the server it would be a single round trip.

          Early SPA's did this, they would load a shell and then begin fetching from the client. Some still do but we know better than to do this for things that aren't web apps.

          • Mikhail_Edoshin 17 hours ago

            The stylistic includes and certain content (e. g. a site map) can be embedded in the XSLT itself.

            It is not quite a templating engine. XSLT is a part of a semantic engine. Content is written in the way that fits the content. E. g. I write about some language and invent tags and notations that best fit what I am talking about: grammar, sounds, wrtiting. Or I write about chess and say something like (party id=abc move=15w). Then I make it available in HTML by providing a transform from my tags to HTML tags. My notation is rendered as a bunch of divs, ps and spans. This is merely a temporary rendering; other renderings may be possible.

            A templating engine is the final document with placeholders for variable parts. XSLT can do that too, but this is less than its vision.

          • lelanthran 16 hours ago

            > You end up with a really bad waterfall where it can take a long time for a page to load because it's going back to the server constantly, whereas if you did it on the server it would be a single round trip.

            These are all static file downloads, though. The first page load will take long, but if these are header/footer type includes, every subsequent page will use the cached file.

            It's a trade-off between longer times for landing page and shorter times for every other page. The developer will decide whether or not to make the trade-off.

  • msylvest 15 hours ago

    I remember admiring the intent of XSLT when it was born. And how difficult it turned out to be to write; using XML framing makes it terse/verbose/arcane, eg. when compared to the compactness of regex/subs.

    It is 2025 and now we've got LLMs to write our code - that may actually be a strong argument in favor of keeping XSL(T): It is a useful browser mechanism and LLMs makes it easier to harvest.

    Does anybody have experience with LLM-generated XSL(T)?

    • reacweb 13 hours ago

      I have 1 "big" xsl file in a project I maintain. I have fixed an issue this year. I have tried to use chatgpt prompt. The scope was perfect: I had the buggy xsl, the buggy result, the expected result and a clear explanation. It generated syntactically correct code (almost) that did not work because chatgpt does not understand. This was not a complete loss: a good refresher of the syntax, but I had to do the thinking fully alone and found alone how to use "node-set".

      My previous change in this file was in 2017 when I replaced xalan by the xslt processor built in java. I was very surprised I had to make the following changes:

          -<xsl:if test="string(serverName)=$sName">
          +<xsl:if test="string(serverName)=string($sName)">
      
          -<xsl:for-each select="attributeList/attribute[self::attribute!='']">
          +<xsl:for-each select="attributeList/attribute[text()!='']">
      
          -<xsl:if test="preceding-sibling::Connection[featureType='Receptacle'][position() = 1]/@Name!=@Name or not(preceding-sibling::Connection[featureType='Receptacle'][position() = 1]/node()) ">
          +<xsl:if test="preceding-sibling::Connection[position() = 1]/@Name!=@Name or position()=1">
      
      These incompatibility issues with something I considered to be standard greatly damaged my opinion on xslt.
  • mjaniczek 13 hours ago

    Reminds me of Symphony CMS, which is XSLT based. Cool concept but not entirely practical in my experience.

    • ulrischa 5 hours ago

      Cool project. Sadly it seems to be unmaintained

  • OCTAGRAM 21 hours ago

    The most advanced usage of XSLT I've seen was in YBlog2, YML and YSLT, an alternative syntax for XML and XSLT. And IIUC they did not rely on browser-side although that may be still possible.

  • RebeccaTheDev a day ago

    Three jobs ago I worked for a company that did e-learning systems for industrial clients. This was roughly 2004. One of the company owner's many ideas was a technical documentation system based on XML and XSLT. The "idea" being that technical writers or SMEs would rather write XML than, you know, use a word processor.

    Unsurprisingly the idea did not take off, but I did find the XML/XSLT combination to be very interesting.

    • the_other 15 hours ago

      Between 2000 and 2003 I worked for a company that produced corporate training materials (initially on CDROM, later as learning-management-system units). We had a system which allowed the content authors to write in structured Word files. VBA would create XML of the Word files, and XSLT would create the HTML. I mostly worked in the XSLT and JS/CSS layers, not on the XML generation layer. It was my first job out of uni and I found XSLT fascinating and slightly psychedelic.

    • Telemakhos 15 hours ago

      Is this DITA? I always wondered who actually used that.

      XSLT is also big in the TEI community in digital humanities. TEI gives a structured markup for reproducing printed volumes, which is important when you are dealing with variants of the same text, like revised editions of a text. XSLT lets you turn your TEI file into a web page for humans to read.

  • DonHopkins 12 hours ago

    What's the whole point of bending over backwards to be "JavaScript-free" when the chosen alternative is using something as half-assedly hamstrung and counterintuitively crippled and mind-bogglingly rube-goldbergesque as XSLT, that tries to be all things to all people, thus satisfying no-one?

    My impression of XSLT's design is that there were partisan representatives from every popular programming language paradigm on the XSLT standard committee, and each one of them was able to get just enough to showcase what was special about their own paradigm into the standard, while strategically sabotaging all the other competing paradigms to undermine and beclown each other, but not enough for practical coherency, or lord forbid neatly dovetailing together into a synergistic design.

    When the Lisp faction evals and applies their functional paradigm, the BASIC faction runs to goto their imperative paradigm, and the Prolog faction is horny and unified that its logical paradigm makes the cut, the result is dysfunctional emparitive illogical programming.

    Jeff Atwood points out that "Martin Fowler hates XSLT too":

    https://blog.codinghorror.com/martin-fowler-hates-xslt-too/

    I have no problem with XML. It’s a fine way to store hierarchical data in a relatively simple, mostly human-readable format. But I’ve always disliked its companion technology, XSLT. While useful in theory – “using a simple XSLT transform, XML can be converted into anything!”– in practice, it takes painful contortions to do anything practical. Evidently I’m not alone; Martin Fowler hates XSLT too:

    >All of this site is written in simple XML documents and transformed to HTML. I find this works really well, and means I never have to worry about dealing with HTML formats. (Not that fancy layout is my style, as you can tell.) I’ve even written a whole book that way.

    >For most of this time I’ve used XSLT as my transformation language. I’ve got pretty good with slinging XSLT around and getting it to do what I want.

    >But no more.

    >When I wrote the software for this Bliki (on a long flight) I did it in Ruby. Prior to that I used Ruby to do a new version of my home page. My conclusion from this exercise was that using Ruby for XML transforms was much easier than using XSLT.

    I’ve had almost the same exact argument with a few developers I used to work with. After working through a bit of the XSLT necessary to accomplish something, I concluded that it was easier and simpler to use procedural code to do the same thing. Not always, of course, but most of the time. As Fowler points out, this does beg the question: what good is XSLT?

    I think this may raise some real questions about XSLT. There’s still much I like about the power of XSLT, but I hate the syntax and the walls you keep running into. I’m not going to convert my whole site over to Ruby tomorrow – most of the XSLT works fine - but I can certainly see my way to doing that at some point in the future. But the bigger question is whether you’re better off with scripting language for this kind of task than XSLT.

    Maybe the idea of XSLT transforming XML into “anything” is fundamentally unrealistic – just more Write Once, Run Anywhere snake oil.

  • em-bee 13 hours ago

    this is exactly how i built my site with help of a fellow HNer: https://news.ycombinator.com/item?id=44966886

  • postepowanieadm 14 hours ago

    Can we have xml/xhtml back? It makes perfect sense in the age of LLMs.

  • cranberryturkey 14 hours ago

    I'm bummed that w3c dropped xslt