Bootstrap Popover не обновляет переменную Scope

0

Как только пользователь нажмет на поле ввода. Я хочу получить идентификатор поля ввода и фильтровать объект и связать данные в окне Popover. Но Scope не обновляется из директивы. Ниже приведен код, пожалуйста, дайте мне знать, где я делаю неправильно

  var app = angular.module('MyModule', []);
    app.controller("TestController", function ($scope, $window) {
        //$scope.ID = '0';
        $scope.myObj = [{ "ID": 0, "Name": 'user0' }, { "ID": 1, "Name": 'user1' }, { "ID": 2, "Name": 'user2' }]

        $scope.GetData = function () {

            var match = $.grep($scope.myObj, function (e) {
                return e.ID == $scope.myID
            });

            return match;
        };

    });

    app.directive('popOver', function ($compile, $timeout) {
        return {
            restrict: 'A', 
            link: function (scope, el, attrs) {
                $(el).bind('click', function () {
                    scope.$apply(function () {
                        scope.myID = attrs.popoverid ;
                    });
                });


                $(el).popover({
                    placement: 'bottom',
                    container: 'body',
                    trigger: "click",
                    content: $compile($('#popover-content').html())(scope)
                });
            }
        };
    });


 <div ng-repeat="i in [0,1,2]">
         <input  style="background: transparent"
            type="text"
            pop-over
            popoverid="{{i}}" 
             id="{{i}}"
            class="form-control enterTime" data-html="true">
        <br /><br />
    </div>


    <div class="bottom hide" id="popover-content">
        <div class="arrow" style="left: 47%;"></div>
        <div class="Bground-Project"> 
            <table>
                <tr>
                    <td>
                        {{GetData()}}
                    </td>
                </tr>
            </table> 
            <button type="button" ng-click="buttonClicked()">click me</button> 
        </div>
    </div> 
Теги:
bootstrap-popover

1 ответ

0
Лучший ответ

когда примитивный тип (т.е. строка, число или логический тип) записывается в - например, scope.name = newName - "запись" всегда идет в локальную область/объект. Другими словами, дочерняя область получает свое собственное свойство name, которое затеняет родительское свойство с тем же именем. Исправление состоит в том, чтобы использовать объект, а не примитивный тип, в родительской области. Затем дочерняя область получит ссылку на этот объект. Любые записи свойств объекта (будь то из родителя или дочернего элемента) будут переходить к одному объекту. (Масштабирование ребенка не получает свой собственный объект.)

Возможно ли обновить родительский охват из Угловой директивы с областью действия: истина?

Ещё вопросы

Сообщество Overcoder
Наверх
Меню