@bornkiller
2015-03-09T10:33:15.000000Z
字数 1522
阅读 2242
angularjs
Angularjs
的思维方式是通过数据带动DOM
变动,通常依托指令与控制器的配合来实现。就表单操作上,提供了几乎完备的操作体验。对于官方没有实现的功能,只能自己来实现。比如说在做表单校验时,使用编码方式实现控件的focus
。
如下为一个简易表单,auto-focus-when
为负责控件focus
的指令。
<form class="form-horizontal" name="form" role="form" ng-controller="FocusCtrl">
<div class="form-group">
<label for="username" class="col-sm-2 control-label" >用户名</label>
<div class="col-sm-5">
<input type="text" ng-model="username" name="username"
id="username" class="form-control" auto-focus-when="usernameFocus" >
</div>
</div>
<div class="form-group">
<label for="bookname" class="col-sm-2 control-label" >书名</label>
<div class="col-sm-5">
<input type="text" ng-model="bookname" name="bookname"
id="bookname" class="form-control" auto-focus-when="booknameFocus">
</div>
</div>
</form>
指令内容比较简单,不做过多说明。
angular.module('shuffleApp', [])
.directive('autoFocusWhen', ['$log','$timeout', function($log, $timeout) {
return {
restrict: 'A',
scope: {
autoFocusWhen: '='
},
link: function(scope, element) {
scope.$watch('autoFocusWhen', function(newValue) {
if (newValue) {
$timeout(function(){
element[0].focus();
})
}
});
element.on('blur', function() {
scope.$apply(function() {
scope.autoFocusWhen = false;
})
})
}
}
此处控制器与指令本是同级,此处分开说明之用。通过控制器内部的变量控制,即可实现表单控件的focus
控制。
angular.module('shuffleApp', [])
.controller('FocusCtrl', ['$scope', '$interval', function($scope, $interval) {
$scope.usernameFocus = false;
$scope.booknameFocus = true;
$interval(function() {
$scope.usernameFocus = $scope.usernameFocus ? false : true;
$scope.booknameFocus = $scope.booknameFocus ? false : true;
}, 1500, 3);
}])
QQ:491229492
Email: hjj491229492@hotmail.com