назначение методов прототипа в функции конструктора: потенциальные ловушки
стилистически, некоторые предпочитают следующую структуру для определения методов прототипа:
var Filter = function( category, value ){ this.category = category; this.value = value; // product is a JSON object Filter.prototype.checkProduct = function( product ){ // run some checks return is_match; } };
. Однако этот подход имеет несколько недостатков по сравнению с альтернативной структурой:
var Filter = function( category, value ){ this.category = category; this.value = value; };// var Filter = function(){...} Filter.prototype.checkProduct = function( product ){ // run some checks return is_match; }
функциональные недостатки:
var Counter = function(initialValue){ var value = initialValue; // product is a JSON object Counter.prototype.get = function() { return value ; } }; var c1 = new Counter(0); var c2 = new Counter(10); console.log(c1.get()); // outputs 10, should output 0Другие соображения:
. В то время как первая структура может быть стилистически приятной, она может ввести функциональные недостатки и проблемы с объемом. Обычно рекомендуется назначить методы прототипа вне функции конструктора (как во второй структуре), чтобы избежать потенциальных проблем. ]
Отказ от ответственности: Все предоставленные ресурсы частично взяты из Интернета. В случае нарушения ваших авторских прав или других прав и интересов, пожалуйста, объясните подробные причины и предоставьте доказательства авторских прав или прав и интересов, а затем отправьте их по электронной почте: [email protected]. Мы сделаем это за вас как можно скорее.
Copyright© 2022 湘ICP备2022001581号-3