javascript - Django/AngularJS : How do I access my Python Context Items from my AngularJS Script

标签 javascript python angularjs json django

美好的一天!我是一名初学者,正在尝试 Django 项目,同时使用 AngularJS 作为我的前端 Firebase 聊天系统。这是我之前就该项目提出的问题:Firebase/Angular: Messages not showing in HTML, but contain the message objects

我知道在使用 django/python 时直接在 html 上使用 json 变量是不明智的,但碰巧我的 firebase 聊天模块正在使用 angularJS (而且我不知道如何在中编写此聊天功能django..),而我的 angularJS 代码需要从 View.py 访问我的 Django 上下文查询集。

有什么办法可以:

  1. 将 json 项目推送到我的 HTML/模板中,就像推送上下文一样 信息从 Views.py 导入到我的 HTML/模板中,并在我的 AngularJS 脚本?
  2. 从 Views.py 的 Context 访问我的 Django/Python 数据集?

这是我的 firebase AngularJS 代码:

var app = angular.module('chatApp', ['firebase']);

app.controller('ChatController', function($scope, $firebaseArray) {

    //I want to populate the crisis and sender variables  with something from my context 
    //from Views.py.. Inside planList

    var crisis = "Crisis1"; 
    var sender = "Sender1";

    //Query

    var ref = firebase.database().ref().child(crisis).child('CMO-PMO');

    $scope.messages = $firebaseArray(ref);

    $scope.send = function() {
        $scope.messages.$add({
            sender: sender,
            message: $scope.messageText,
            date: Date.now()
        })
    }
})

这是我的 Views.py 代码:

def home(request):
    template = loader.get_template('app/home.html')
    planList = Plan.objects.filter(plan_crisisID__crisis_status='Ongoing')

    context = {        
        'planList': planList
    }
    return HttpResponse(template.render(context, request))

我的 AngularJS 代码中需要的两个变量(crisis 和 sender)都来自 planList 上下文。

有什么办法可以让我实现这个目标吗?请给我一些帮助。非常感谢您,我非常感激:)如果需要,我很乐意提供任何其他信息,并且也会及时回复!

最佳答案

我认为最好使用 API。您可以使用 DRF 创建 API非常简单地。例如:

# Serializer
class SomeSerializer(serializers.ModelSerializer):
   class Meta:
        model = Plan
        fields = ('model_fields',)

# Views:
from rest_framework import generics


Class SomeView(generics.ListView):
      queryset = Plan.objects.all()
      serializer_class = SomeSerializer


# urls

url(r'^plans$', SomeView.as_view()),

在 Angular JS 中,如果使用 angular-resource ,您可以简单地通过以下方式获取数据:

res = $resource('/plans')
res.query().$promise.then(function(data) {
    console.log(data)},  // You get your data in here
    function(error) {
    console.log(error)}
)

关于javascript - Django/AngularJS : How do I access my Python Context Items from my AngularJS Script,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46762014/

相关文章:

javascript - Google Analytics 'not set' 值作为浏览器版本?

javascript - D3 元素被删除,尽管我只是添加新元素

javascript - 这个 jQuery 有问题吗?

python - 如何在python 2.7中逐行从pdf中提取文本

javascript - 在 Angular 带中正确悬挂 anchor ScrollSpy

javascript - 在 Cordova 中将 handleOpenURL 与自定义 URL 方案结合使用

javascript - 从视觉力页面将 html 添加到闪电组件

javascript - AsyncIterable 和 Observable 之间的实际区别是什么?

python - 程序根本不运行

python - pandas 在通过条件选择时失败