ドキュメント に続いて、私はやった:
var collection = new Backbone.Collection.extend({
model: ItemModel,
url: '/Items'
})
collection.fetch({ data: { page: 1} });
uRLは次のようになりました:http://localhost:1273/Items?[object%20Object]
http://localhost:1273/Items?page=1
のようなものを期待していました
それでは、どのようにフェッチメソッドでパラメータを渡すのですか?
変化:
collection.fetch({ data: { page: 1} });
に:
collection.fetch({ data: $.param({ page: 1}) });
そのため、やり直すことなく、これは{data: {page:1}}
オブジェクトでoptions
として呼び出されます
Backbone.sync = function(method, model, options) {
var type = methodMap[method];
// Default JSON-request options.
var params = _.extend({
type: type,
dataType: 'json',
processData: false
}, options);
// Ensure that we have a URL.
if (!params.url) {
params.url = getUrl(model) || urlError();
}
// Ensure that we have the appropriate request data.
if (!params.data && model && (method == 'create' || method == 'update')) {
params.contentType = 'application/json';
params.data = JSON.stringify(model.toJSON());
}
// For older servers, emulate JSON by encoding the request into an HTML-form.
if (Backbone.emulateJSON) {
params.contentType = 'application/x-www-form-urlencoded';
params.processData = true;
params.data = params.data ? {model : params.data} : {};
}
// For older servers, emulate HTTP by mimicking the HTTP method with `_method`
// And an `X-HTTP-Method-Override` header.
if (Backbone.emulateHTTP) {
if (type === 'PUT' || type === 'DELETE') {
if (Backbone.emulateJSON) params.data._method = type;
params.type = 'POST';
params.beforeSend = function(xhr) {
xhr.setRequestHeader('X-HTTP-Method-Override', type);
};
}
}
// Make the request.
return $.ajax(params);
};
そのため、「データ」を jQuery.ajax に送信します。これは、params.data
がURLに追加されるように最善を尽くします。
ProcessDataをtrueに設定することもできます。
collection.fetch({
data: { page: 1 },
processData: true
});
Jqueryはデータオブジェクトを自動的にパラメーター文字列に処理し、
しかし、Backbone.sync関数では、Backboneは他のメソッドを使用してPOST、UPDATE ...のデータを処理するため、BackboneはprocessDataをオフにします。
バックボーンソース:
if (params.type !== 'GET' && !Backbone.emulateJSON) {
params.processData = false;
}
チタン合金を使用している場合の別の例:
collection.fetch({
data: {
where : JSON.stringify({
page: 1
})
}
});