Bir projede ECMAScript6 kullanıyorum ve bir Açısal Filtre oluşturmaya çalışıyorum. Aşağıda benim girişimi, ancak konsolda aşağıdaki hatayı alıyorum: undefined özelliği 'PassFilter' özelliği ayarlanamıyorECMAScript6 AngularJS Süzgeç
Hem ES6 hem de Angular için yeniyim. Eski sınırlamalar nedeniyle bu şekilde açılıyorum. Açısal içinde
myAngularModule = angular.module("MyModule");
angular.element(document).ready(function() {
var myDiv = $("#myAngularDiv");
angular.bootstrap(myDiv, ["MyModule"]);
});
myAngularModule.filter('PassFilter', APP.filters.PassFilter);
/* Filter is in a separate file: */
class PassFilter {
constructor(input) {
var split = input.split('');
var result = "";
for (var i = 0; i < split.length; i++) {
result += "*";
}
return result;
}
}
APP.filters.PassFilter = PassFilter;
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<div id="myAngularDiv">
<input type="password" ng-model="password">
<span>{{password | PassFilter}}</span>
</div>
Yorumlarınız dayanarak, APP.filters tanımlanmamış olduğu görülmektedir. – POZ
@POZ - evet başka bir dosyada tanımlanmıştır, sadece ana malzeme bu durumda bir snippet gösteriyorum:/ – user1809790
Evet, bunu anlıyorum. Benim söylediklerim: Kütüphanelerinizin doğru sırada yüklenmemiş olması olabilir mi? Örneğin, HTML'imin sonundaki (harici komut dosyalarıyla en iyi uygulama) açısal komut dosyasını yerleştirirdim. – POZ