how to make a meteor template helper re-run/render after another template has rendered?

后端 未结 2 1047
日久生厌
日久生厌 2021-01-01 01:27

I have a template helper called {{renderNav}} in a template Nav

e.g.

Template.Nav.renderNav

and within that helper function I want

相关标签:
2条回答
  • 2021-01-01 01:50

    If you want the navigation to be automatically rebuilt when contentWindow renders, as Hubert OG suggested, you can also use a cleaner, lower level way of invalidating contexts:

    var navDep = new Deps.Dependency;
    
    Template.contentWindow.rendered = function() {
        ...
        navDep.changed();
    }
    
    Template.renderNav.contentData = function() {
        navDep.depend();
    
        // Get the data you need and prepare for displaying
        ...
    }
    

    See http://docs.meteor.com/#deps for more info.

    If, on the other hand, you want to render another template manually, you can call it as a function:

    var html = Template.contentWindow();
    

    The returned html will not be reactive. If you need reactivity, use:

    var reactiveFragment = Meteor.render(Template.contentWindow);
    

    See the screencasts at http://www.eventedmind.com/ on Spark and reactivity for details on how this works.

    UPDATE

    To add a rendered fragment to your DOM:

    document.body.appendChild(Meteor.render(function () {
        return '<h1>hello</h1><b>hello world</b>';
    }));
    

    You can also access the rendered nodes directly using the DOM API:

    console.log(reactiveFragment.childNodes[0]);
    
    0 讨论(0)
  • 2021-01-01 01:53

    You need a dependency in the template that you want to rerun. There are few possibilities, depending on what data you want to get.

    For example, you can set a reactive marker in the content template that will notify renderNav that it's done with drawing.

    Template.contentWidnow.rendered = function() {
        ...
    
        // Set this on the very end of rendered callback.
        Session.set('contentWindowRenderMark', '' +
            new Date().getTime() +
            Math.floor(Math.random() * 1000000) );
    }
    
    
    Template.renderNav.contentData = function() {
        // You don't have to actually use the mark value,
        // but you need to obtain it so that the dependency
        // is registered for this helper.
        var mark = Session.get('contentWindowRenderMark');
    
        // Get the data you need and prepare for displaying
        ...
    }
    

     


     

    With further information you've provided, we can create such code:

    content.js

    Content = {};
    Content._dep = new Deps.Dependency;
    

    contentWindow.js

    Template.contentWidnow.rendered = function() {
        Content.headers = this.findAll(':header');
        Content._dep.changed();
    }
    

    renderNav.js

    Template.renderNav.contentData = function() {
        Content._dep.depend();
        // use Content.headers here
        ...
    }
    
    0 讨论(0)
提交回复
热议问题