首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >无法使用带有Handlebars.js模板的Jquery从Json获取html数据

无法使用带有Handlebars.js模板的Jquery从Json获取html数据
EN

Stack Overflow用户
提问于 2013-06-18 07:11:03
回答 1查看 729关注 0票数 0

我有一个json文件,它包含如下的json数据:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{
    "username":"lgangula",
    "message":""
}

在data.json文件中

我使用jquery ajax方法获取文件,并使用Handlebars.js追加数据;下面是函数:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var JsonHandler = function(url) {
        return $.getJSON(url)
};

(function ($) {

    var manupulate = function(data){
        $.each(data, function(key,value){
            if(key === "username"){
                            console.log(value) // i am getting the name
                var x = Handlebars.compile($("#header-template").html());
                console.log(x(value));//i am getting the elements, without the value..!?
            }
        })
    }


    var path = "js/data.json";
    new JsonHandler(path).done(function(data){
        manupulate(data);
    })

})(jQuery);

我没有得到我的html输出中的值。下面是我使用的模板:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<script id="header-template" type="text/x-handlebars-template">
        <div class="loginInfo"> <a href="#">{{username}}</a> | <a href="#">Logout</a> </div>
    </script>

这里到底出了什么问题..有谁能帮我吗?

甚至我也再次尝试过这种方式:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
(function ($) {

    var x = {"username":"lgangula"}


    var manupulate = function(data){
        $.each(x, function(key,value){
            if(key === "username"){
                console.log(value);//consoling the name
                var x = Handlebars.compile($("#header-template").html());
                console.log(x(value)); //no result here.
                            console.log(x({"username":"lgangula"})); //works fine
            }
        })
    }

    manupulate();

})(jQuery);

还是不能工作..

如果我像这样传递对象,它就能正常工作。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
console.log(x({"username":"lgangula"})); //works fine
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-06-18 11:21:08

您尚未呈现模板,请尝试此操作,

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var template = Handlebars.compile($("#header-template").html());
 var html =  template(x)
 console.log(html) 
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17162660

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文