みんな。angularjsに問題があります。input[type="text"] のカスタム ディレクティブを作成し、モデルとして変数に渡しました。しかし、ng-change イベントは、変数の前の値で関数を呼び出しました。例: 状態: 0、タイプ 1、機能中 - 0。状態: 1、タイプ 548、機能中 - 1。状態: 548、タイプ 3、機能中 548。
私のHTML:
<div ng-controller="simpleCTRL">
<mr-textfield is-required="true" value="val" title="Minutes" type="text" change="ChangeVal()"></mr-textfield>
<input type="text" ng-model="val" ng-change="ChangeVal()"/>
</div>
</div>
そしてjs:
<!-- language: lang-js -->
angular.module('SimpleInterestApp', [])
.controller('simpleCTRL', function($scope) {
$scope.val = 0;
$scope.ChangeVal = function() {
console.log($scope.val);
};
})
.directive('mrTextfield', function () {
return {
restrict: 'E',
template: "<div class='textfield'><input type='{{::type}}' ng-required='isRequired' ng-model='value' ng-change='change()'><span class='bar'></span><label>{{::title}}</label></div>",
replace: true,
transclude: true,
scope: {
value:"=",
title:"@",
type:"@",
isRequired:"=",
change:"&"
}
};
});