ejs icon indicating copy to clipboard operation
ejs copied to clipboard

Functions do not return embedded HTML

Open pautasso opened this issue 10 months ago • 2 comments

view.ejs file:

<% function f() { %>
<p>from function</p>
<% } %>

<%-include("include", {f}) %>

include.ejs file:

from include
<main><%-f() %></main>

The output will be:

<p>from function</p>
from include
<main></main>

As opposed to:

from include
<main><p>from function</p></main>

Functions emit the embedded html by appending it to the output of the view in which they are declared. If they are called from another view, they will not use the "correct" output buffer of the .ejs in which they are called from but the one in which they have been declared.

pautasso avatar Aug 31 '23 15:08 pautasso

Yeah, the function just appends at call time. This can be demonstrated by the fact that <% f() %> (scriptlet tag, not an output tag) will still output <p>from function</p>. If you want your function to actually return something, you'd write it like this:

<% function f() {
  return '<p>from function</p>'
} %>

Of course, you wouldn't be able to use EJS inside the function. Defining functions in EJS is generally inconvenient; you probably want to make your function an included partial instead.

RyanZim avatar Aug 31 '23 19:08 RyanZim

(...leading to many small partial include files, which could have been functions instead)

Thanks for the explanation, maybe the documentation could be clarified to say something like:

One can use functions with ejs, but those functions do not return the embedded HTML/JS content.

pautasso avatar Sep 04 '23 14:09 pautasso