首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JQuery模板不适用于$.get

JQuery模板不适用于$.get
EN

Stack Overflow用户
提问于 2015-11-11 21:28:57
回答 2查看 29关注 0票数 0

我正在用Jquery模板填充表。在此模板中,我需要通过ajax调用使用json文件进行填充。

代码语言:javascript
复制
$(document).ready(function() {
    var clientData;

    $.get("/webpro/webcad/lngetusuario", function(data, status){
        clientData = data;
        alert(clientData);
    });
    $("#clientTemplate").tmpl(clientData).appendTo("tbody");

});

<script id="clientTemplate" type="text/html">
    <tr><td> ${usuario} </td><td> ${nome} </td><td> ${setor} </td></tr>
     //{{tmpl($data) "#phoneTemplate"}}
</script>

url '/webpro/webcad/lngetusuario‘生成json文件。

这就是代码。我不明白这一点,因为在$.get语句中,变量clientData具有正确的json值,但是在$.get语句之外(在document.ready上),变量clientData是空的。

有人能帮我吗?

EN

回答 2

Stack Overflow用户

发布于 2015-11-11 21:31:58

这是一个回调的“特性”。

代码并不是按照您认为的顺序运行的:

代码语言:javascript
复制
$(document).ready(function() {
    var clientData;

    $.get("/webpro/webcad/lngetusuario", function(data, status){
        clientData = data; // This will be run when a response has been received from the server
        alert(clientData);
    });
   // This will run without waiting any reply from the server
    $("#clientTemplate").tmpl(clientData).appendTo("tbody");

});

以下是您需要的内容:

代码语言:javascript
复制
$(document).ready(function() {
    var clientData;

    $.get("/webpro/webcad/lngetusuario", function(data, status){
        clientData = data;
        alert(clientData);
        $("#clientTemplate").tmpl(clientData).appendTo("tbody");
    });

});
票数 0
EN

Stack Overflow用户

发布于 2015-11-11 21:32:16

$.get()是异步的。因此,$().tmpl()$.get()完成之前执行,导致clientData为空。要解决此问题,请将$().tmpl()放入$.get()回调中。这将确保只有在get请求完成时才会创建模板。就像这样

代码语言:javascript
复制
$.get("/webpro/webcad/lngetusuario", function(data, status){
    clientData = data;
    alert(clientData);
    $("#clientTemplate").tmpl(clientData).appendTo("tbody");
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33651582

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档