1
  • jQuery 1.7.2
  • jQuery 検証 1.1.0
  • jQuery フォーム 3.18
  • ワードプレス 3.4.2

上記の環境で/上記のjQueryライブラリを使用して、連絡先/メールフォームをコーディングしようとしています。現在、jQuery Form JS に問題があります。

の開発者ページから元のコードを取得しajaxSubmit、 target オプションを HTML ソースに存在する ID に変更し$、 function の jQuery に置き換えただけshowRequestです。

問題は、後に名付けられた関数が起動success:しないことです。私は同じことを試みましたが、error:何も発火しませんでした。

しただけで、そこに配置した関数は、受信スクリプトからcomplete:警告を発しました。responseText

誰かが何がうまくいかないのか考えていますか?

コード:

jQuery(document).ready(function() {
var options = { 
    target:        '#mail-status',   // target element(s) to be updated with server response 
    beforeSubmit:  showRequest,  // pre-submit callback 
    success:       showResponse,  // post-submit callback 

    // other available options: 
    //url:       url         // override for form's 'action' attribute 
    //type:      type        // 'get' or 'post', override for form's 'method' attribute 
    //dataType:  null        // 'xml', 'script', or 'json' (expected server response type) 
    //clearForm: true        // clear all form fields after successful submit 
    //resetForm: true        // reset the form after successful submit 

    // $.ajax options can be used here too, for example: 
    //timeout:   3000 
};
jQuery("#mailform").validate(
{
    submitHandler: function(form)   { jQuery(form).ajaxSubmit(options); },
    errorPlacement: function(error, element) { },
    rules: {
        author: {
            minlength: 2,
            required: true
        },
        email: {
            required: true,
            email: true
        },
        comment: {
            minlength: 2,
            required: true
        }
    },
    highlight: function(element) 
    {
        jQuery(element).addClass("e");
        jQuery(element.form).find("label[for=" + element.id + "]").addClass("e");
    },
    unhighlight: function(element) 
    {
        jQuery(element).removeClass("e");
        jQuery(element.form).find("label[for=" + element.id + "]").removeClass("e");
    }
});
});
// pre-submit callback 
function showRequest(formData, jqForm, options) { 
// formData is an array; here we use $.param to convert it to a string to display it 
// but the form plugin does this for you automatically when it submits the data 
var queryString = jQuery.param(formData); 

// jqForm is a jQuery object encapsulating the form element.  To access the 
// DOM element for the form do this: 
// var formElement = jqForm[0]; 

alert('About to submit: \n\n' + queryString); 

// here we could return false to prevent the form from being submitted; 
// returning anything other than false will allow the form submit to continue 
return true; 
} 
// post-submit callback 
function showResponse(responseText, statusText, xhr, $form)  { 
// for normal html responses, the first argument to the success callback 
// is the XMLHttpRequest object's responseText property 

// if the ajaxSubmit method was passed an Options Object with the dataType 
// property set to 'xml' then the first argument to the success callback 
// is the XMLHttpRequest object's responseXML property 

// if the ajaxSubmit method was passed an Options Object with the dataType 
// property set to 'json' then the first argument to the success callback 
// is the json data object returned by the server 

alert('status: ' + statusText + '\n\nresponseText: \n' + responseText + 
    '\n\nThe output div should have already been updated with the responseText.'); 
} 
4

2 に答える 2

0

検証が成功しjQuery(form).ajaxSubmit(options);て呼び出されるかどうかを確認します。

于 2012-11-16T10:57:36.573 に答える
0

これは元の質問者による編集として追加されました。編集ではなく回答である必要があるため、コミュニティ wiki の回答に変換しました。

理由/エラーが見つかりました。これは、テーマのサブディレクトリに保存した jquery.form.js をエンキューした方法が原因でした。

wp_enqueue_script のハンドルとして「jquery-form」を渡しました。「jquery-form」はすでに WP によって割り当てられており、jquery.form.js を含む WP に接続されています。含まれているバージョン (2.x) は、渡したオプションに対応していませんでした。

割り当てられたスクリプトを登録解除し、テーマに保存されている現在の jquery.form.js へのハンドルを登録する必要がありました。

于 2015-06-22T19:49:17.193 に答える