6

Rails 3 で delete/destroy が機能しません。

足場や新しいプロジェクトのためのものではありません。

<%= link_to 'Destroy', card, :confirm => 'Are you sure?', :method => :delete %> 

この質問から。解決策は、Firefox の再インストールです。しかし、私のものはクロム、サファリ、またはオペラでも機能していません。

生成された HTML コード:--

 <a href="/categories/1" data-confirm="Are you sure?" data-method="delete" rel="nofollow">Destroy</a>

PS: デフォルトの JS ファイルなどを含めるとは言わないでください。私はjQueryを使用しているため、プロトタイプにはまったく興味がありません。

編集/更新、重要:これは、プロトタイプをまったく使用したくない場合の解決策です。プロジェクトでは jQuery とそれぞれのプラグインのみを使用しています。

人々は答えています:最初にプロトタイプなどを含めてから、プロトタイプとjQueryの間の競合を取り除くためにgemなどをインストールしてください。それはゴミです。

回答を投稿しました。オプションをお選びになる前に、一度ご確認ください。何の問題もなく10以上のプロジェクトで私のために働きました。あなたがする必要があるのは次のとおりです。

application.js を除くすべての js ファイルを JavaScript ディレクトリから削除します。次に、回答で指定したコードを新しいファイルに貼り付け、そのファイルを含めます。Jquery.js をインクルードすれば準備完了です。競合などを削除するために、デフォルトの JavaScript (つまり、プロトタイプ) やその他の gem を追加する必要はありません。

4

4 に答える 4

8

PrototypeではなくjQueryを使用している場合は、プロジェクトにJquery.rails.jsを追加する必要があります。そうしないと、何かを削除しようとするたびに、ページが表示されます。

ソリューションとこのJquery.rails.jsファイルをどこから入手したか覚えていません。しかし、確かにいくつかの信頼できる情報源から。

そのファイルのコードは次のとおりです。

jQuery(function ($) {
    var csrf_token = $('meta[name=csrf-token]').attr('content'),
        csrf_param = $('meta[name=csrf-param]').attr('content');

    $.fn.extend({
        /**
         * Triggers a custom event on an element and returns the event result
         * this is used to get around not being able to ensure callbacks are placed
         * at the end of the chain.
         *
         * TODO: deprecate with jQuery 1.4.2 release, in favor of subscribing to our
         *       own events and placing ourselves at the end of the chain.
         */
        triggerAndReturn: function (name, data) {
            var event = new $.Event(name);
            this.trigger(event, data);

            return event.result !== false;
        },

        /**
         * Handles execution of remote calls firing overridable events along the way
         */
        callRemote: function () {
            var el      = this,
                data    = el.is('form') ? el.serializeArray() : [],
                method  = el.attr('method') || el.attr('data-method') || 'GET',
                url     = el.attr('action') || el.attr('href');

            if (url === undefined) {
              throw "No URL specified for remote call (action or href must be present).";
            } else {
                if (el.triggerAndReturn('ajax:before')) {
                    $.ajax({
                        url: url,
                        data: data,
                        dataType: 'script',
                        type: method.toUpperCase(),
                        beforeSend: function (xhr) {
                            el.trigger('ajax:loading', xhr);
                        },
                        success: function (data, status, xhr) {
                            el.trigger('ajax:success', [data, status, xhr]);
                        },
                        complete: function (xhr) {
                            el.trigger('ajax:complete', xhr);
                        },
                        error: function (xhr, status, error) {
                            el.trigger('ajax:failure', [xhr, status, error]);
                        }
                    });
                }

                el.trigger('ajax:after');
            }
        }
    });

    /**
     *  confirmation handler
     */
    $('a[data-confirm],input[data-confirm]').live('click', function () {
        var el = $(this);
        if (el.triggerAndReturn('confirm')) {
            if (!confirm(el.attr('data-confirm'))) {
                return false;
            }
        }
    });


    /**
     * remote handlers
     */
    $('form[data-remote]').live('submit', function (e) {
        $(this).callRemote();
        e.preventDefault();
    });
    $('a[data-remote],input[data-remote]').live('click', function (e) {
        $(this).callRemote();
        e.preventDefault();
    });

    $('a[data-method]:not([data-remote])').live('click', function (e){
        var link = $(this),
            href = link.attr('href'),
            method = link.attr('data-method'),
            form = $('<form method="post" action="'+href+'">'),
            metadata_input = '<input name="_method" value="'+method+'" type="hidden" />';

        if (csrf_param != null && csrf_token != null) {
          metadata_input += '<input name="'+csrf_param+'" value="'+csrf_token+'" type="hidden" />';
        }

        form.hide()
            .append(metadata_input)
            .appendTo('body');

        e.preventDefault();
        form.submit();
    });

    /**
     * disable-with handlers
     */
    var disable_with_input_selector = 'input[data-disable-with]';
    var disable_with_form_selector = 'form[data-remote]:has(' + disable_with_input_selector + ')';

    $(disable_with_form_selector).live('ajax:before', function () {
        $(this).find(disable_with_input_selector).each(function () {
            var input = $(this);
            input.data('enable-with', input.val())
                 .attr('value', input.attr('data-disable-with'))
                 .attr('disabled', 'disabled');
        });
    });

    $(disable_with_form_selector).live('ajax:after', function () {
        $(this).find(disable_with_input_selector).each(function () {
            var input = $(this);
            input.removeAttr('disabled')
                 .val(input.data('enable-with'));
        });
    });
});

アップデート

ここからJquery.rails.jsの最新のコピーを入手できます。

   https://raw.github.com/rails/jquery-ujs/master/src/rails.js
于 2011-05-07T19:07:27.280 に答える
8

Mohit と同じ問題に遭遇し、JavaScript アセットに「控えめな JavaScript ライブラリ」(または「ujs」) を含める必要もありました。私の現在の Rails (v3.2.5) では、UJS ライブラリが自動的に提供されます。これは、Gemfile で次の行を確認することで確認できます。

gem 'jquery-rails'

app/assets/javascripts/application.js ファイルの次の行:

//= require jquery_ujs

よくわからなかったのでrequire jquery_ujs、自分の application.js ファイルからその行を削除しましたが、link_to ..., :method => :delete呼び出しが機能しなくなった理由を理解するのにしばらく時間がかかりました!

問題を理解すると、上記の 2 行をそれぞれのファイルに簡単に追加し直すことができ、すべてが期待どおりに機能し始めました。

于 2012-06-22T17:47:11.570 に答える
4

レイアウトにデフォルトのRailsjavascriptファイルが含まれていることを確認してください。

<%= javascript_include_tag :defaults %>
于 2010-09-24T07:40:49.267 に答える
2

レイアウトにデフォルトの Rails JavaScript ファイルが含まれていることを確認してください。

<%= javascript_include_tag "application" %>
于 2012-03-13T21:13:26.320 に答える