Rails 4 App… in der Entwicklungsumgebung wird Javascript erst ausgelöst, wenn die Seite aktualisiert wurde

Ich habe also ein seltsames Problem mit meiner ersten Rails4-App, bei der meine Seite nicht mit Javascript gestartet wird, es sei denn, ich lade die Seite neu.

Dies gilt sowohl für meine Asset-Pipeline JS als auch für content_for JS.

In meiner /assets/javascripts/cars.js Datei:

$(function(){
    $("#car_car_make_id").on("change", function(){
        //SET MODELS
        $.ajax({
            url: "/car_makes/" + $(this).val() + "/car_models",
            type: "GET",
            dataType: "json",
            cache: false
        })
        .done(function(data) { model_list(data) })
        .fail(function() { alert("error"); })
    });
});

function model_list(data) {
    $("#car_car_model_id").empty();
    $.each(data, function(i,v){ 
        $("<option />").val(v.id).text(v.name).appendTo("#car_car_model_id");
    });
    //ON COMPLETE SHOW
    $("#car_model_div").show();
}

Inline in Seite mit content_for:

<% content_for :head do %>
<script type="text/javascript">
    var tag = document.createElement('script');
    tag.src = "https://www.youtube.com/iframe_api";
    var firstScriptTag = document.getElementsByTagName('script')[0];
    firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);

    var player;
    function onYouTubeIframeAPIReady() {
        player = new YT.Player('yt_vid', {
            height: '390',
            width: '640',
            videoId: '<%= @timeslip.youtube_id %>'
        });
    }
</script>
<% end %>

Beide feuern nur, wenn ich die Seite aktualisiere.

Wenn ich zum Beispiel auf einen Link zu der Seite mit dem YouTube-Video klicke, wird dieser nicht geladen. aber wenn ich es auffrische wird es. Wie beim Asset-Pipeline-Skript wird nur dann ein Ajax-Aufruf ausgeführt, wenn die Seite zuerst neu geladen wird.

Antworten auf die Frage(4)

Ihre Antwort auf die Frage