Using interpolation within Node.js EJS includes

后端 未结 4 1017
天涯浪人
天涯浪人 2021-02-07 09:46

My Express app is using EJS, and my views directory looks like this:

./views
  ./contents
    home.ejs
  ./includes
    header.ejs
    footer.ejs
  layout.ejs


        
相关标签:
4条回答
  • 2021-02-07 10:28

    In the version 2 of EJS, the include function does it well. With it, includes are inserted at runtime so variables can be used as pathnames.

    In this case, the solution may be :

    <%- include('contents/' + contents) %>
    

    The function can also have another argument if necessary :

    <%- include('mypathname', {foo:"bar"}) %>
    

    The pathname has to be relative to the template which calls the function.

    0 讨论(0)
  • 2021-02-07 10:37

    Currently this hasn't been implemented into ejs but, there is this discussion and pull request that offers the functionality.

    https://github.com/visionmedia/ejs/issues/93

    0 讨论(0)
  • 2021-02-07 10:39

    I think there is no way to do this kind of dynamic includes in EJS. It might break the separation of business logic and view. The solution can be to rendering the subtemplate in the controller, and passing its content to the layout.

    For rendering subtemplate in the controller use something like this:

    var ejs = require('ejs'),
    , fs = require('fs')
    , home = ejs.render(fs.readFileSync("contents/home.ejs", "utf-8"))
    
    0 讨论(0)
  • 2021-02-07 10:45

    in your render function you can include fs.readFileSync and __dirname.

    Render your page with options like this

    res.render('pages/'+req.file,{file_get_contents:fs.readFileSync,__dirname:__dirname});
    

    Then you can use it in your .ejs page like this. This remains in server side.

    <% var products=JSON.parse(file_get_contents(__dirname+'/web/data/products.json','utf8')) %>
    

    You can print the data on client HTML like this.

    <%- JSON.stringify(products)%>
    

    Note : Using this method means you have fs included somewhere at the top of your script.

    var fs = require('fs')
    
    0 讨论(0)
提交回复
热议问题