Javascript'te argüman aşırı yüklemesinin birçok yönü vardır:
Değişken bağımsız değişkenler - Farklı bağımsız değişken kümeleri (hem tür hem de miktar olarak) iletebilirsiniz ve işlev, kendisine iletilen bağımsız değişkenlerle eşleşen bir şekilde davranır.
Varsayılan bağımsız değişkenler - Aktarılmamışsa bir bağımsız değişken için varsayılan bir değer tanımlayabilirsiniz.
Adlandırılmış bağımsız değişkenler - Bağımsız değişken sırası önemsiz hale gelir ve yalnızca işleve iletmek istediğiniz bağımsız değişkenleri adlandırırsınız.
Aşağıda, bu argüman işleme kategorilerinin her biri hakkında bir bölüm bulunmaktadır.
Değişken Argümanlar
JavaScript'in bağımsız değişkenler üzerinde tür denetimi veya gerekli bağımsız değişken sayısı olmadığından, yalnızca bir uygulamanız olabilir. myFunc() olmadığından, bağımsız değişkenlerin türünü, varlığını veya miktarını kontrol ederek kendisine iletilen bağımsız değişkenlere uyum sağlayabilen sahip olabilirsiniz.
jQuery bunu her zaman yapar. Bazı bağımsız değişkenleri isteğe bağlı yapabilir veya kendisine iletilen bağımsız değişkenlere bağlı olarak işlevinizde dallara ayrılabilirsiniz.
Bu tür aşırı yüklemeleri uygularken, kullanabileceğiniz birkaç farklı tekniğiniz vardır:
- Belirtilen bağımsız değişken adı değerinin olup olmadığını kontrol ederek herhangi bir bağımsız değişkenin varlığını kontrol edebilirsiniz
undefined.
- Toplam miktarı veya argümanları ile kontrol edebilirsiniz
arguments.length.
- Herhangi bir argümanın türünü kontrol edebilirsiniz.
- Değişken sayıdaki bağımsız değişkenler için,
argumentsherhangi bir bağımsız değişkene erişmek için sözde diziyi kullanabilirsiniz arguments[i].
İşte bazı örnekler:
JQuery'nin obj.data()yöntemine bakalım . Dört farklı kullanım biçimini destekler:
obj.data("key");
obj.data("key", value);
obj.data();
obj.data(object);
Her biri farklı bir davranışı tetikler ve bu dinamik aşırı yükleme biçimini kullanmadan dört ayrı işlev gerektirir.
İşte tüm bu seçenekleri İngilizce'de nasıl ayırt edebileceğiniz ve sonra hepsini kodda birleştireceğim:
// get the data element associated with a particular key value
obj.data("key");
Aktarılan ilk bağımsız değişken .data()bir dizeyse ve ikinci bağımsız değişken ise undefined, arayanın bu formu kullanıyor olması gerekir.
// set the value associated with a particular key
obj.data("key", value);
İkinci bağımsız değişken tanımsız değilse, belirli bir anahtarın değerini ayarlayın.
// get all keys/values
obj.data();
Hiçbir bağımsız değişken iletilmezse, döndürülen bir nesnedeki tüm anahtarları / değerleri döndürür.
// set all keys/values from the passed in object
obj.data(object);
İlk bağımsız değişkenin türü düz bir nesneyse, o nesneden tüm anahtarları / değerleri ayarlayın.
Tüm bunları tek bir javascript mantığı kümesinde nasıl birleştirebileceğiniz aşağıda açıklanmıştır:
// method declaration for .data()
data: function(key, value) {
if (arguments.length === 0) {
// .data()
// no args passed, return all keys/values in an object
} else if (typeof key === "string") {
// first arg is a string, look at type of second arg
if (typeof value !== "undefined") {
// .data("key", value)
// set the value for a particular key
} else {
// .data("key")
// retrieve a value for a key
}
} else if (typeof key === "object") {
// .data(object)
// set all key/value pairs from this object
} else {
// unsupported arguments passed
}
},
Bu tekniğin anahtarı, kabul etmek istediğiniz tüm argüman biçimlerinin benzersiz bir şekilde tanımlanabilir olduğundan ve arayanın hangi formu kullandığı konusunda hiçbir zaman kafa karışıklığı olmadığından emin olmaktır. Bu genellikle argümanların uygun şekilde sıralanmasını ve hangi formun kullanıldığını her zaman anlayabileceğiniz argümanların türü ve konumunda yeterli benzersizlik olduğundan emin olmayı gerektirir.
Örneğin, üç dize argümanı alan bir işleviniz varsa:
obj.query("firstArg", "secondArg", "thirdArg");
Üçüncü argümanı kolayca isteğe bağlı hale getirebilir ve bu koşulu kolayca tespit edebilirsiniz, ancak yalnızca ikinci argümanı isteğe bağlı yapamazsınız çünkü arayanın hangisinin geçeceğini söyleyemezsiniz çünkü ikinci argümanı tanımlamanın bir yolu yoktur. argüman, ikinci argüman anlamına gelir veya ikinci argüman ihmal edildi, bu nedenle ikinci argümanın yerinde olan aslında üçüncü argümandır:
obj.query("firstArg", "secondArg");
obj.query("firstArg", "thirdArg");
Üç bağımsız değişken de aynı türde olduğundan, farklı bağımsız değişkenler arasındaki farkı söyleyemezsiniz, böylece arayanın ne istediğini bilemezsiniz. Bu çağrı stiliyle, yalnızca üçüncü argüman isteğe bağlı olabilir. İkinci bağımsız değişkeni atlamak isterseniz, bunun nullyerine (veya başka bir algılanabilir değer) olarak iletilmesi gerekir ve kodunuz şunu algılar:
obj.query("firstArg", null, "thirdArg");
İsteğe bağlı bağımsız değişkenlerin bir jQuery örneğini burada bulabilirsiniz. her iki bağımsız değişken de isteğe bağlıdır ve geçirilmezse varsayılan değerleri alır:
clone: function( dataAndEvents, deepDataAndEvents ) {
dataAndEvents = dataAndEvents == null ? false : dataAndEvents;
deepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents;
return this.map( function () {
return jQuery.clone( this, dataAndEvents, deepDataAndEvents );
});
},
İşte bağımsız değişkenin eksik olabileceği bir jQuery örneği veya size dört farklı aşırı yükleme sağlayan üç farklı türden herhangi biri:
html: function( value ) {
if ( value === undefined ) {
return this[0] && this[0].nodeType === 1 ?
this[0].innerHTML.replace(rinlinejQuery, "") :
null;
// See if we can take a shortcut and just use innerHTML
} else if ( typeof value === "string" && !rnoInnerhtml.test( value ) &&
(jQuery.support.leadingWhitespace || !rleadingWhitespace.test( value )) &&
!wrapMap[ (rtagName.exec( value ) || ["", ""])[1].toLowerCase() ] ) {
value = value.replace(rxhtmlTag, "<$1></$2>");
try {
for ( var i = 0, l = this.length; i < l; i++ ) {
// Remove element nodes and prevent memory leaks
if ( this[i].nodeType === 1 ) {
jQuery.cleanData( this[i].getElementsByTagName("*") );
this[i].innerHTML = value;
}
}
// If using innerHTML throws an exception, use the fallback method
} catch(e) {
this.empty().append( value );
}
} else if ( jQuery.isFunction( value ) ) {
this.each(function(i){
var self = jQuery( this );
self.html( value.call(this, i, self.html()) );
});
} else {
this.empty().append( value );
}
return this;
},
Adlandırılmış Bağımsız Değişkenler
Diğer diller (Python gibi), yalnızca bazı argümanları iletmek ve argümanları geçirildikleri sıradan bağımsız hale getirmek için bir kişinin adlandırılmış argümanları iletmesine izin verir. Javascript, adlandırılmış argümanların özelliğini doğrudan desteklemez. Onun yerine yaygın olarak kullanılan bir tasarım modeli, özelliklerin / değerlerin bir haritasını geçirmektir. Bu, özelliklere ve değerlere sahip bir nesneyi ileterek yapılabilir veya ES6 ve üzerinde, aslında bir Harita nesnesinin kendisini iletebilirsiniz.
İşte basit bir ES5 örneği:
jQuery's $.ajax() , özelliklere ve değerlere sahip normal bir Javascript nesnesi olan tek bir parametreyi ilettiğiniz bir kullanım biçimini kabul eder. Hangi özellikleri ilettiğiniz, ajax çağrısına hangi argümanların / seçeneklerin aktarılacağını belirler. Bazıları gerekli olabilir, çoğu isteğe bağlıdır. Bir nesnenin özellikleri olduklarından, belirli bir sıra yoktur. Aslında, bu nesneye aktarılabilen 30'dan fazla farklı özellik vardır, yalnızca bir (url) gereklidir.
İşte bir örnek:
$.ajax({url: "http://www.example.com/somepath", data: myArgs, dataType: "json"}).then(function(result) {
// process result here
});
Uygulamanın içinde, $.ajax()daha sonra gelen nesnede hangi özelliklerin aktarıldığını sorgulayabilir ve bunları adlandırılmış argümanlar olarak kullanabilir. Bu, for (prop in obj)tüm özellikleri bir diziye alarak Object.keys(obj)veya bu diziyi yineleyerek yapılabilir.
Bu teknik, çok sayıda bağımsız değişken olduğunda ve / veya birçok bağımsız değişken isteğe bağlı olduğunda Javascript'te çok yaygın olarak kullanılır. Not: Bu, minimum geçerli argüman kümesinin mevcut olduğundan emin olmak ve arayan kişiye yetersiz argüman iletilirse eksik olan bazı hata ayıklama geri bildirimleri vermek için uygulama işlevine bir yük getirir (muhtemelen yararlı bir hata mesajı ile bir istisna atarak) .
Bir ES6 ortamında, yukarıda aktarılan nesne için varsayılan özellikler / değerler oluşturmak için yok etme kullanmak mümkündür. Bu, bu referans makalesinde daha ayrıntılı olarak tartışılmaktadır .
İşte o makaleden bir örnek:
function selectEntries({ start=0, end=-1, step=1 } = {}) {
···
};
Bu , işleve iletilen bir nesnedeki start, endve stepözellikleri için varsayılan özellikler ve değerler oluşturur selectEntries().
İşlev bağımsız değişkenleri için varsayılan değerler
ES6'da Javascript, bağımsız değişkenler için varsayılan değerler için yerleşik dil desteği ekler.
Örneğin:
function multiply(a, b = 1) {
return a*b;
}
multiply(5); // 5
Bunun MDN'de kullanılabileceği yollar hakkında daha fazla açıklama burada .