我在项目中使用 ECMAScript6 并尝试创建角度过滤器。以下是我的尝试,但是我在控制台中收到以下错误:
无法设置未定义的属性“PassFilter”
我对 ES6 和 Angular 都是新手。由于遗留的限制,我不得不以这种方式引导角度。
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>
我是 Angular 的新手。我使用类在 Angular 中创建过滤器。
class PassFilter{
constructor(input){
this.input = input;
}
myMethod() {
let input = this.input;
let split = input.split('');
let result = "";
for (let i = 0; i < split.length; i++) {
result += "*";
}
return result;
}
static PassFilterFactory(input){
let filter = new PassFilter(input);
return filter.myMethod();
}
}
PassFilter.PassFilterFactory.$inject = ['input'];
angular.module('myAngularModule', [])
.filter('passFilter', () => PassFilter.PassFilterFactory);
in html
<span>{{password | passFilter}}</span>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)