我在与范围相关的代码中遇到了一些困难。 这是我的代码:
<script type="text/javascript">
var totalHoras = {};
var dadosCategorias = {"teste": "1234"};
var t; // timeout handler para exibição de feedback para o usuário
$().ready(function() {
// obtém dados das categorias
var obterDadosCategorias = function() {
$.post(
"{{ baseRoute }}/cadastro/categoria/listar"
, {
"ajax": "true"
}
).done(function(data) {
var obj = $.parseJSON(data);
if (obj.result) {
console.log(dadosCategorias); // returns 'object{"teste": "1234"}'
dadosCategorias = obj.data;
console.log(dadosCategorias); // returns 'string(11) "it works!!!"'
} else {
alert('Erro interno: não foi possível obter os dados das categorias');
}
});
};
obterDadosCategorias();
console.log(dadosCategorias); // returns 'object{"teste": "1234"}'
问题是:为什么地狱是第三次调用console.log返回原始var值?是不是被覆盖了?
控制台是
'object{"teste": "1234"}'
'string(11) "it works!!!"'
'string(11) "it works!!!"'
但它是
'object{"teste": "1234"}'
'string(11) "it works!!!"'
'object{"teste": "1234"}'
我试图在$ .ajax()函数中使用带有窗口的“context”选项,但也不起作用:(
答案 0 :(得分:0)
感谢评论家伙们! :d
我找到了答案。问题根本不在于范围。实际上,对console.log()的调用不是脚本的顺序。之前的呼叫顺序是312,现在是123:D 我将ajax方法更改为$ .ajax()而不是$ .post()并将选项'async'设置为false以实现此目的,如下所示:
<script type="text/javascript">
var totalHoras = {};
var dadosCategorias = {"teste": "1234"};
var t; // timeout handler para exibição de feedback para o usuário
$().ready(function() {
// obtém dados das categorias
var obterDadosCategorias = function() {
$.ajax(
"{{ baseRoute }}/cadastro/categoria/listar"
, {
"type": "POST"
, "async": false
, "data": {
"ajax": "true"
}
}
).done(function(data) {
var obj = $.parseJSON(data);
if (obj.result) {
console.log(1, dadosCategorias);
dadosCategorias = obj.data;
console.log(2, dadosCategorias);
} else {
alert('Erro interno: não foi possível obter os dados das categorias');
}
});
};
obterDadosCategorias();
console.log(3, dadosCategorias);