Django, доступ к значению html формы поля, отправленного из JQuery AJAX - PullRequest
0 голосов
/ 22 мая 2018

формы:

class TransactionForm(forms.ModelForm):     
    CHOICES = ((1, 'Buy'), (2, 'Sell'),)

    coin = forms.ModelChoiceField(queryset = Coin.objects.all()) 
    buysell = forms.ChoiceField(choices = CHOICES)

    field_order = ['buysell', 'coin', 'amount', 'trade_price']

    class Meta:
        model = Transaction
        fields = {'buysell', 'coin', 'amount', 'trade_price'}

    def __init__(self, coin_price = None, user = None, *args, **kwargs):
        super(TransactionForm, self).__init__(*args, **kwargs)
        print("Transaction form init: ", user, coin_price)

        if user:
            self.user = user
            qs_coin = Portfolio.objects.filter(user = self.user).values('coin').distinct()
            print("qs_coin test: {}".format(qs_coin))
            self.fields['coin'].queryset = qs_coin

        if coin_price:
            print("coin price test")
            self.coin_price = coin_price
            self.fields['price'] = self.coin_price

Фрагмент jquery:

    $('#id_buysell').on('change', function(){

            console.log("buysell");
            console.log($('#id_buysell').val());

            var $formData = $(this).attr("id_buysell");
            console.log($formData.val());

            $.ajax({
                method: "GET",
                url: "/myportfolio/add_transaction",
                data: $formData,
            });

        });

    $('#id_coin').on('change', function(){

        console.log("coin change")

        var $formData = $(this).attr("id_coin");
        console.log($formData.val());

        $.ajax({
            method: "GET",
            url: "/myportfolio/add_transaction",
            data: $formData,
        });

    });

Фрагмент представления

def add_transaction(request):
    print(request.method)
    print("test1")

    print(request.GET)

    if request.method == "GET":
        if request.is_ajax():
            print("ajax test")

            data = {
                'test': "test1"
            }

            form = TransactionForm(user = request.user, coin_price = GetCoin("Bitcoin").price)

            return JsonResponse(data)

В моих функциях jquery я объявляю

var $ formData = $ (this) .attr ("id_coin");

и затем передать его в представление с помощью GET.Однако я не уверен, как на самом деле получить эти данные на мой взгляд.

Так как я могу получить доступ к этому значению?Если бы я хотел напечатать его, чтобы увидеть это значение, могу ли я сделать что-то подобное или подобное?:

print (request.GET ['coin'])

1 Ответ

0 голосов
/ 22 мая 2018

Вы не можете отправлять данные таким образом через ajax, вам нужно отправить их следующим образом {key:'value',key2:'value2'}

var coin = $(this).attr("id_coin");

$.ajax({
    method: "GET",
    url: "/myportfolio/add_transaction",
    data: {
        id_coin:coin // retrrieve the value in python with the key
    },
});

В ваших представлениях:

print(request.GET.get('coin'))
>>> # The value of coin from JS ajax
...