使用动态<md-menu-content>列表

时间:2016-06-18 13:17:17

标签: angularjs angular-material angular-ng-if

我想根据用户是否记录来使用动态列表填充md-menu-content。代码:

     <md-menu>
        <md-button class="md-icon-button" aria-label="Account" ng-click="$mdOpenMenu($event)">
            <md-icon md-svg-icon="~/../Content/img/icons/ic_account_box_white_48px.svg" class="s48" aria-label="Account"></md-icon>
        </md-button>
        <md-menu-content width="4">
            <md-menu-item ng-if-start="vm.user.isLogged">
                <p>Logged as: {{ vm.user.username }}</p>
            </md-menu-item>
            <md-menu-divider></md-menu-divider>
            <md-menu-item>
                <md-button ng-click="vm.myProfile($event)">
                    My profile
                </md-button>
            </md-menu-item>
            <md-menu-item ng-if-end>
                <md-button ng-click="vm.logout($event)">
                    Logout
                </md-button>
            </md-menu-item>

            <md-menu-item ng-if-start="!vm.user.isLogged">
                <md-button ng-click="vm.openRightSideNav('login')">
                    Login
                </md-button>
            </md-menu-item>
            <md-menu-item>
                <md-button ng-click="vm.openRightSideNav('register')">
                    Register
                </md-button>
            </md-menu-item>
            <md-menu-item class="menu-item-facebook" ng-if-end>
                <md-button ng-click="vm.openRightSideNav('register')">
                    <span class="icon-button-facebook"></span>
                    Log in with Facebook
                </md-button>
            </md-menu-item>
        </md-menu-content>
    </md-menu>

这样可行,但用户退出后会出现闪烁现象。我的意思是,一瞬间所有菜单项都会显示出来。使用ng-switch可以消除闪烁,但是额外的dom元素会破坏菜单:

         <md-menu-content width="4">
            <ng-switch on="vm.user.isLogged">
                <span ng-switch-when="true">
                ...
                </span>
                <span ng-switch-default>
                    ...
                </span>
            </ng-switch>
        </md-menu-content>

有关如何处理这种情况的任何建议吗?

1 个答案:

答案 0 :(得分:2)

你是对的。你的情况有一个闪烁。我尝试以多种不同的方式实施并获得一个解决方案。这不是我必须说的最好的解决方案,但不会有任何闪烁。您只需尝试为logInlogOut使用两个单独的菜单。

以下是示例代码。

<md-menu ng-if="vm.user.isLogged">
 //md-menu-item
</md-menu>
<md-menu ng-if="!vm.user.isLogged">
 //md-menu-item
</md-menu>

这是一个工作示例。 http://codepen.io/next1/pen/wWzebw