javascript - jquery metismenu 无法与 AngularJS Controller 异步加载数据

标签 javascript jquery angularjs asp.net-mvc

我对 Jquerymetis 菜单有疑问。我想从数据库加载菜单元素,我正在使用 AngujarJS Controller 获取带有菜单元素的 JSON。

这里是 AngularJSController

var appControllers = angular.module('appControllers', []);

appControllers.controller('MenuCtrl', ['$scope', '$http',
  function ($scope, $http) {
      var url = "/api/Menus/GetMenuElements";
      $http.post(url).
        success(function (data, status, headers, config) {
            $scope.menuElements = data;
            console.log("Success");
        }).
        error(function (data, status, headers, config) {
            console.log("Error");
        });
  }]);

然后在我的 ASP.NET MVC 项目的 PartialView 中,我使用 Angular 指令将元素添加到菜单。

<ul class="nav" id="side-menu">
    <li ng-repeat="elementL1 in menuElements" ng-init="menuElements != null">
        <a ng-if="elementL1.LINK !== null" href="{{elementL1.LINK}}"><i class="fa fa-home"></i> <span class="nav-label">{{elementL1.NAME}}</span><span class="fa arrow"></span></a>
        <a ng-if="elementL1.LINK == null"><i class="fa fa-home"></i> <span class="nav-label">{{elementL1.NAME}}</span> </a>

        <ul ng-repeat="elementL2 in elementL1.ChildMenu" ng-if="elementL1.ChildMenu.length > 0" class="nav nav-second-level">
            <li class="primerLi">
                <a>{{elementL2.NAME}}<span class="fa arrow"></span></a>
                <ul ng-if="elementL2.ChildMenu.length > 0" class="nav nav-third-level">
                    <li ng-repeat="elementL3 in elementL2.ChildMenu">
                        <a href="{{elementL3.LINK}}">{{elementL3.NAME}}</a>
                    </li>
                </ul>
            </li>
        </ul>
    </li>
</ul>

这可以很好地向菜单添加元素,但无法折叠和展开。它看起来展开了,我无法折叠元素。

我认为问题是我必须在加载元素后调用 $('#side-menu').metisMenu(); 但如果我在浏览器控制台上调用它,它不会'不工作。

如何实现?我是 Angular 的新手。在这里我看到了同样的问题,但我无法解决问题。 https://github.com/onokumus/metisMenu/issues/22

编辑

我发现不能多次调用 Metis 菜单。我已经从 onready 事件 JS 中删除了 $('#side-menu').metisMenu(); 并且我从浏览器控制台调用了它,它现在可以工作了。

现在我需要帮助,以便在加载菜单元素时使用 angular 调用它。我是 Angular 的新手,我需要一些帮助。

最佳答案

我已经解决了当 ng-repeat 的最后一个元素呈现给 DOM 时使用 Angular 指令执行 metisMenu 函数的问题。

app.directive('metis', function ($timeout) {
    return function ($scope, $element, $attrs) {
        if ($scope.$last == true) {
            $timeout(function () {
                $('#side-menu').metisMenu();
            }, 250)
        }
    };
});

然后我必须在 Ng 重复元素上使用指令

<li ng-repeat="elementL1 in menuElements" ng-init="menuElements != null" metis="">

您可以在我的问题上看到完整的 HTML 代码。

我是 Angular 的新手,所以我不是专家。甚至我希望这个解决方案可以帮助某人。

关于javascript - jquery metismenu 无法与 AngularJS Controller 异步加载数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34026478/

相关文章:

javascript - 是否可以在客户端和服务器端设置 td 的宽度?

javascript - 如何使 SVG 在 Skrollr 代码中固定在滚动条上?

javascript - AngularJS $sce.trustAsHtml() 处理大量标记的数据

javascript - 仅小于 24 小时前的 Timeago 日期格式

javascript - ng-model 不更新值

javascript - 使用超链接和按钮提交表单

javascript - 仅在元素显示时才需要必填字段

c# - 在 C# 中测量应用程序所有页面的加载时间

javascript - 使用 gulp 实时重新加载

javascript - ng-repeat 不适用于表 <tr> 但适用于列表 <li>