javascript - Ng-repeat 不适用于 Flask,$scope.variablename = data.result 在 $.post API 调用后超出范围

标签 javascript angularjs python-3.x flask angularjs-ng-repeat

我正在尝试使用 ng-repeat 使用数据库中的数据填充表格。在 $.post 调用 $scope.variable_name = data.result 之后从 flask 获取数据,但它超出了范围,使得 ng-repeat 中使用的变量为空。因此,我在 HTML 标记中出现了空白。

我尝试声明一个全局 $scope.variable1 并从 flask 分配数据,但它仍然不起作用。

HTML代码:

div class="row card_row margin-bottom-10" ng-repeat="item in userdata">
    <div class="col-md-3">
        <span>{{item.name}}</span>
    </div>
    <div class="col-md-3">
        <span>{{item.number}}</span>
    </div>
    <div class="col-md-3">
        <span>{{item.email}}</span>
    </div>
</div>

Javascript 代码:


User.controller("UserController", function ($scope, $rootScope, $window, $http) {
    $scope.getUserDetails = function getUserDetails() {
        $.post('/getDetails', function (data) {
            $scope.userdata = data.result;
            console.log("log1: ",$scope.userdata);//second in console //prints 
             data
        });
        console.log("log2: ",$scope.userdata);//first in console //prints 
             null
    }
});

Python-flask 代码:

@app.route('/getDetails', methods=["POST","GET"])
def getDetails():
    to_send=[{'name': 'abcd', 'number': 1234567890, 'email': 'abcd@abcd.com'}, 
    {'name': 'efgh', 'number': 1234567890, 'email': 'efgh@abcd.com'}, 
    {'name': 'ijkl', 'number': 1234567890, 'email': 'ijkl@abcd.com'}]   
    return jsonify(result=to_send)

我希望 ng-repeat 可以使用从 flask 传递到 $scope 的详细信息,并以表格格式打印数据。但是我得到的输出是 {{item.name}} 和其他 {{}} 标签中的空白,因为 $scope.userdata 超出了范围。

当前控制台输出:

log2: undefined
log1: [{'name': 'abcd', 'number': 1234567890, 'email': 'abcd@abcd.com'}, 
      {'name': 'efgh', 'number': 1234567890, 'email': 'efgh@abcd.com'}, 
      {'name': 'ijkl', 'number': 1234567890, 'email': 'ijkl@abcd.com'}]

最佳答案

看起来您正在使用 jQuery 的 $.post 方法进行 ajax 调用 - 有什么特别的原因吗?最好使用 Angular 的 $http.post 方法。这是适合我的代码版本:

<!-- get_details.html template -->
<!doctype html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.7.8/angular.min.js"></script>
  <script>
    var User = angular.module('User', []);
    User.controller("UserController", function ($scope, $rootScope, $window, $http) {
      $scope.userdata = [];
      $scope.getUserDetails = function getUserDetails() {
        $http.post('/getDetails').then(function (data) {
          $scope.userdata = data.data.result;
          console.log("log1: ", $scope.userdata);//second in console //prints data
        });
        console.log("log2: ", $scope.userdata);//first in console //prints null
      };
    });
  </script>
</head>
{% raw %}
<body ng-app="User" ng-controller="UserController">
<button ng-click="getUserDetails()">Fetch userdata</button>
<div class="row card_row margin-bottom-10" ng-repeat="item in userdata">
  <div class="col-md-3">
    <span>{{ item.name }}</span>
  </div>
  <div class="col-md-3">
    <span>{{ item.number }}</span>
  </div>
  <div class="col-md-3">
    <span>{{ item.email }}</span>
  </div>
</div>
</body>
{% endraw %}
</html>

我不需要对您的后端代码进行任何更改,只需更改前端即可。

关于javascript - Ng-repeat 不适用于 Flask,$scope.variablename = data.result 在 $.post API 调用后超出范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57514723/

相关文章:

javascript - 选择第二个框时触发事件,Angular

python - Pyenv 指向正确的版本, "python"但不是 "python3"

javascript - 如何在 javascript 中制作新闻小部件?

javascript - 将 JSON 值加载到各自的 HTML 元素中

javascript - angucomplete 初始值不显示

javascript - HTML5 视频播放完毕后是否已将自身重置为开始?

javascript - 绑定(bind) JSON 数据时 HTML 表格渲染缓慢

angularjs - 我的站点可以用 Chrome 打开,但不能用 IE

python - 以 0.05 为增量向上舍入

python - 使用逻辑填充缺失数据 Pandas