AJAX の標準またはメッセージング フレームワークはありますか?
現在、Ajax を使用してコンテンツをロードする 1 つのページがあります。コンテンツの一部としてデータ入力用の複雑なフォームがあったため、フォームで発生する可能性がある特定のイベントを検証する必要があります。したがって、私のテストによって引き起こされたいくつかの調整の後:
asyncShould("search customer list click", 3, function() {
stop(1000);
$('#content').show();
var forCustomerList = newCustomerListRequest();
var forShipAndCharge = newShipAndChargeRequest(forCustomerList);
forCustomerList.page = '../../vt/' + forCustomerList.page;
forShipAndCharge.page = 'helpers/helper.php';
forShipAndCharge.data = { 'action': 'shipAndCharge', 'DB': '11001' };
var originalComplete = forShipAndCharge.complete;
forShipAndCharge.complete = function(xhr, status) {
originalComplete(xhr, status);
ok($('#customer_edit').is(":visible"), 'Shows customer editor');
$('#search').click();
ok($('#customer_list').is(":visible"), 'Shows customer list');
ok($('#customer_edit').is(":hidden"), 'Does not show customer editor');
start();
};
testController.getContent(forShipAndCharge);
});
コンテンツを取得するためのコントローラーは次のとおりです。
getContent: function (request) {
$.ajax({
type: 'GET',
url: request.page,
dataType: 'json',
data: request.data,
async: request.async,
success: request.success,
complete: request.complete
});
},
そして、ここにリクエストイベントがあります:
function newShipAndChargeRequest(serverRequest) {
var that = {
serverRequest: serverRequest,
page: 'nodes/orders/sc.php',
data: 'customer_id=-1',
complete: errorHandler,
success: function(msg) {
shipAndChargeHandler(msg);
initWhenCustomer(that.serverRequest);
},
async: true
};
return that;
}
そして、成功ハンドラは次のとおりです。
function shipAndChargeHandler(msg) {
$('.contentContainer').html(msg.html);
if (msg.status == 'flash') {
flash(msg.flash);
}
}
サーバー側では、最終的に次のような JSON 構造になります。
$message['status'] = 'success';
$message['data'] = array();
$message['flash'] = '';
$message['html'] = '';
echo json_encode($message);
したがって、コンテンツのロードは次の 2 つの部分で構成されます。
- HTML、これはフォームのプレゼンテーションです。
- DATA、これはフォームにロードする必要があるデータです
- FLASH、検証またはサーバー エラー
- STATUS は、サーバーで何が起こったかをクライアントに伝えます。
私の質問は次のとおりです。これは、クライアント側でイベント メッセージングを処理する有効な方法ですか、それとも心痛と痛みの道をたどっていますか?