2017-08-20 15 views
1

私はいくつかダムのエラーがあることを知っています私は行方不明です。 Pycharm/Bracketsは助けられず、私は十数回それを梳かしました。JQuery/Django構文エラー

誰かが予約スロット(スロット)をクリックしたとき、予約しているか、消去しているか、誰かが既にそれを持っているためブロックされているという考えがあります。返されるエラーは、41行目の"SyntaxError: missing : after property id"です。"console.log()"です。私は読んできましたが、それはおそらく他のところで構文エラーですが、私は困惑しています。

#views.py 
@ensure_csrf_cookie 
def reserve(request): 
    if request.is_ajax(): 
     pk = request.POST['pk'] 
     slot = Event.objects.get(pk=pk) 
     user = request.user 
     if slot.is_reserved == True: 
      if user == slot.teacher: 
       slot.is_reserved = False 
       slot.teacher = None 
       slot.save() 
       result = "clear" 
      else: 
       result = "blocked" 
     else: 
      slot.is_reserved = True 
      slot.teacher = user 
      slot.save() 
      result = "reserved" 
    result = {'result': result} 
    return HttpResponse(json.dumps(result, cls=DjangoJSONEncoder)) 

//main.js 
function getCookie(name) { 
    var cookieValue = null; 
    if (document.cookie && document.cookie != '') { 
     var cookies = document.cookie.split(';'); 
     for (var i = 0; i < cookies.length; i++) { 
      var cookie = jQuery.trim(cookies[i]); 
      // Does this cookie string begin with the name we want? 
      if (cookie.substring(0, name.length + 1) == (name + '=')) { 
       cookieValue = decodeURIComponent(cookie.substring(name.length + 1)); 
       break; 
      } 
     } 
    } 
    return cookieValue; 
} 
$.ajaxSetup({ 
    beforeSend: function (xhr, settings) { 
     if (!(/^http:.*/.test(settings.url) || /^https:.*/.test(settings.url))) { 
      // Only send the token to relative URLs i.e. locally. 
      xhr.setRequestHeader("X-CSRFToken", getCookie('csrftoken')); 
     } 
    } 
}); 
$(document).ready(function() { 
    console.log('ready!'); //Sanity check 
    var count = 0; //Set Count 
    $('button').click(function() { 
     console.log('we clicked!'); // Sanity Check II 
     event.preventDefault(); 
     var pk = this.id 
     var user = $('button').attr("user") 
     count++ //Increase the count towards reload 
     console.log(pk, user) // Sanity Check III 
     $.ajax({ 
      url: "/reserve/", 
      type: "POST", //Send the info to reserve view 
      data: { 
       pk: pk 
      }, 
      dataType: "json", 
      console.log('form submitted') // Sanity check IV (I may have a problem) 
      success: function (result) { 
       if (result.result == 'clear') { 
        $(this).toggleClass("free reserved"); 
        $.toast({ 
         heading: "Reservation Clear!", 
         icon: 'success', 
         stack: 4, 
         hideAfter: 2000, 
         bgColor: '#003366', 
        }); 
       }; 
       if (result.result == 'reserved') { 
        $("div.tchr").html(user); //Send user info to button, reverts on refresh 
        $(this).toggleClass("free reserved"); 
        $.toast({ 
         heading: "Reservation Complete!", 
         icon: 'success', 
         stack: 4, 
         hideAfter: 2000, 
        }); 
       }; 
       if (result.result == 'blocked') { 
        alert("This slot is already reserved! Maybe refresh your browser?") 
       }; 
      }; 
     }); 
     if (count > 4) { 
      var count = 0 
      $('#main_view').load(document.URL + ' #main_view'); //Reload if the count hits four 
     } 
    }); 
}); 
//End button function 

$(document).ready(function() { 
    console.log('ready!'); //Sanity check 
    $('#toggle').click(function() { 
     var $this = $(this); 
     console.log('we clicked!'); 
     $('#main_view').toggle('500'); 
     $('#my_view').toggle('500'); 
     $this.toggleClass('one'); 
     if ($this.hasClass('one')) { 
      $this.text('My Reservations'); 
     } else { 
      $this.text('Today'); 
     } 
    }); 

}); 
+2

複数のconsole.logがあります – mplungjan

答えて

2

以下の行を削除すると間違いなく動作します。 params for ajaxでは、完全に間違っているconsole.logを入れています。

$.ajax({ 
      url: "/reserve/", 
      type: "POST", //Send the info to reserve view 
      data: { 
       pk: pk 
      }, 
      dataType: "json", 
      console.log('form submitted') <-- remove this line 
      success: function (result) { 
       if (result.result == 'clear') { 
        $(this).toggleClass("free reserved"); 
        $.toast({ 
         heading: "Reservation Clear!", 
         icon: 'success', 
         stack: 4, 
         hideAfter: 2000, 
         bgColor: '#003366', 
        }); 
       }; 

注:あなたがあなたのコードをデバッグしたいならば、あなたが渡すか、どのようなJSコードのあなたの流れがあるされているものは何でも、デバッグに役立つだろうアヤックスから機能のようなbeforesendを置くことができます。