当gn模型为true时,如何将焦点转移到输入上

How to move focus on input when gn-model is true?

本文关键字:焦点 转移 输入 模型 gn true      更新时间:2023-09-26

我有div对象和输入字段,它们放在隐藏的表单上。当我点击div时,表单会显示出来,焦点必须移到输入字段上。

<div ng-click="createForm = true">
    Create item
</div>
<div ng-show="createForm">
    <form class="form-horizontal">
        <div class="input-group">
            <input type="text" ng-blur="createForm = false">
        </div>
    </form>
</div>

我用using指令找到了解决方案,但它不起作用。

app.directive('focusOn', function() {
    return function(scope, elem, attr) {
        scope.$on(true, function(e){
            elem[0].focus();
        });
        scope.$on(attr.focusOn, function(e) {
            elem[0].focus();
        });
    };
});

您没有应用指令?

<input type="text" ng-blur="createForm = false" focus-on="createForm">

请参阅此JSFiddle

HTML

<div ng-app="myApp" ng-controller="myController">
    <div ng-click="createForm = true">
        Create item
    </div>
    <div ng-show="createForm">
        <form class="form-horizontal">
            <div class="input-group">
                <input type="text" ng-blur="createForm = false" focus-on="createForm">
            </div>
        </form>
    </div>
</div>

JavaScript

var app = angular.module("myApp", []);
app.directive('focusOn', function() {
    return {
        limit: 'A',
        scope: {
            focusOn: "="
        },
        link: function(scope, elem, attr) {
            scope.$watch("focusOn", function(e){
                elem[0].focus();
            });
        }
    }
});
app.controller("myController", ["$scope", function($scope){
    $scope.createForm = false;
}]);