How can I precompile HandlebarsJS templates from Visual Studio?

后端 未结 3 1748
悲哀的现实
悲哀的现实 2021-02-03 12:57

Is it possible to precompile Handlebars Templates from a postbuild event of Visual Studio or in the App_Start of a MVC web app? Thanks so much in advance. Dale

相关标签:
3条回答
  • 2021-02-03 13:38

    Sure, you have many options:

    1. You can install node.js for windows and npm, and configure a post-build event to the compilation (example here from previous question)
    2. If you're using ember.js, here's an implementation that uses bundle transformation to achieve precompilation.
    3. Another for ember.js that supports components, here's the implementation, that also uses bundle transformation.
    4. Here is an example of compilation on C# using the Jurassic javascript compiler
    0 讨论(0)
  • 2021-02-03 13:44

    I know this question was on Visual Studio 2010 but I found it when looking for a solution to Handlebars recompile in VS2013. I spent some time looking at solutions until I found that Web Essentials for Visual Studio added auto-precompile of handlebars templates in November 2014.

    This feature in Web Essentials is not very well publicised and I only found it when I was building my solution and found that a .hbs.js file automatically appeared when I edited a handlebar .hbs file! I wasted a lot of time looking for solutions when it was already there.

    I hope this answer helps someone else.

    0 讨论(0)
  • 2021-02-03 13:52

    One way to do this is using bundle transform and the jurrasic js compiler to generate a js file with all your compiled views and partial views in it.

    public class BundleConfig
    {
        public static void RegisterHandlBarBundles(BundleCollection bundles, string path)
        {
            HandleBarBundleTransform transform = new HandleBarBundleTransform();
            transform.jsPath = path;
            bundles.Add(new Bundle("~/views.js", transform).IncludeDirectory("~/views", "*.hbs", true));
            BundleTable.EnableOptimizations = true;
        }
    }
    

    This has the benefit of not requiring node.js or ember while still using a simple bundletransform hook.

    The full source for the HandleBarBundleTransform is here.

    This has the convenience of the ember solution(s) @ahmed posted for those not using ember.

    0 讨论(0)
提交回复
热议问题