私はajaxを使用してデータベースに保存するためにビューにデータを渡しています。 JavaScriptではデータが正しく表示されますが、ビューはnullです。 他の質問のためのコード内のコメントや情報Ajaxはデータを送信しません
を読むマイjavascript
:
...
var changed_element=[];
var changed_value=[];
document.getElementById('tabella').addEventListener('change', function(event){
...
changed_element.push(element); //list of list of string
changed_value.push(elem[elem.value].text); //list of string
...
});
document.getElementById('btn-save').addEventListener('click', function() {
console.log('changed_element', changed_element) //print the right value
$.ajax({type: 'POST',
url: '/salva-conoscenze-rapporti/',
data: {
changed_element: changed_element,
changed_value: changed_value //<= comma?
},
success: function(msg) {
console.log(msg) //prints 'It works'
document.getElementById('btn-save').style.display = 'none';
} //<= comma?
});
});
マイview
:
@staff_member_required
@ensure_csrf_cookie #I need this?
def salva_conoscenze_rapporti(request):
if request.is_ajax():
changed_element = request.POST.get('changed_element', None)
changed_value = request.POST.get('changed_value', None)
msg='it works'
print(changed_element) #prints None instead of array
print(changed_value)
else:
msg="it doesn't work"
return HttpResponse(msg)
マイtemplate base.html
:
...
<script>
var csrftoken = $.cookie('csrftoken');
function csrfSafeMethod(method) {
// these HTTP methods do not require CSRF protection
return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
}
$.ajaxSetup({
beforeSend: function(xhr, settings) {
if (!csrfSafeMethod(settings.type) && !this.crossDomain) {
xhr.setRequestHeader("X-CSRFToken", csrftoken);
}
}
});
</script>
...
マイtemplate
:
{% extends 'base.html' %}
...
は、基本的にはprint(changed_element)
代わりにデータを与えるNone
を与える必要があります。
マイMIDDLEWARE_CLASSES
settings.py
中:
MIDDLEWARE_CLASSES = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.locale.LocaleMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
マイ変数:
changed_element=[ [ "conoscenza", "Cliente1", "Cliente2" ] ];
changed_value=[ "Generale" ];
console.log(changed_element)
ができます:Array [ Array[3] ]
これは実際のコードではありません。なぜなら、眩しい構文eerrorがあるからです。実際のコードを投稿した場合、解決策が見つかるかもしれません。 – e4c5
申し訳ありませんが、単純化されています...ああ、たぶんあなたはmsgと言うでしょう...私はそれを翻訳します – fabio
多分javascriptの変数の範囲ですか?またはcsrfの何か? – fabio