我应该如何应用 if-else 条件来向具有不同用户角色的人显示不同的菜单?

Posted

技术标签:

【中文标题】我应该如何应用 if-else 条件来向具有不同用户角色的人显示不同的菜单?【英文标题】:How should I apply if-else condition to display different menu to people with different user roles? 【发布时间】:2016-09-03 19:51:18 【问题描述】:

我定义了两个用户角色,即

1:管理员用户的角色 ID 和 2:普通用户的角色 ID

我尝试的逻辑已经写在两个javascript代码文件中(.js文件如下):

第一个文件:prj.js

var ref = new Firebase("https://prj.firebaseio.com");
var loggedInUser = [];
$(document).ready(function() 
    authData=ref.getAuth();

    if(authData == null)
        //TODO find an elegant way to manage authorization 
    //  window.location = "../index.html";
    else
        ref.child("users").child(authData.uid).on("value", function(snapshot)
            $( "span.user-name").html(snapshot.val().displayName);  
            loggedInUser.displayName = snapshot.val().displayName;
            loggedInUser.roleId = snapshot.val().roleId;
        );         
    
);

第二个文件:navigation.js

appraisalMenuHTML = '       <li class="appraisal" class="dropdown"><a class="dropdown-toggle appraisal"'
    +'          data-toggle="dropdown"  href="/prj/pages/appraisal/appraisalDashboard.html"><span id="appraisal"> Appraisal</span></a>'
    +'          <ul class="dropdown-menu">'
    +'              <li><a href="/prj/pages/appraisal/appraisalDashboard.html">Submit review </a></li>'
    +       ' </ul></li>';

userOptionsHTML = ' <ul class="nav navbar-nav navbar-right">'
    +'      <li class="dropdown"><a class="dropdown-toggle"'
    +'          data-toggle="dropdown" href="#"><img src="/prj/images/settings.png"/></a>'
    +'          <ul class="dropdown-menu">'
    +'              <li><a href="/prj/pages/appraisal/reports.html"> Appraisal</a></li>'
    +'          </ul>'
    +       '</li>'
    +'      <li class="dropdown"><a class="dropdown-toggle user-name"'
    +'          data-toggle="dropdown" href="#"><span class="user-name"></span><span class="caret"></span></a>'
    +'          <ul class="dropdown-menu">'
    +'              <li><a href="/prj/pages/profile.html"> Profile</a></li>'
    +'              <li><a href="/prj/index.html"> Logout</a></li>'
    +'          </ul>'
    +       '</li>'
    +'  </ul>';



navHTML = 
    '<nav class="navbar navbar-inverse">'
    +'<div class="container-fluid">'
    +'<div class="navbar-header">'
    +'  <button class="navbar-toggle" type="button" data-toggle="collapse"'
    +'      data-target="#securedNavbar">'
    +'      <span class="icon-bar"></span> <span class="icon-bar"></span> <span'
    +'          class="icon-bar"></span>'+' </button>'+'</div>'+'<div class="collapse navbar-collapse" id="securedNavbar">'
    +'  <ul class="nav navbar-nav">'
    +'      <li class="feeds"><a href="/prj/pages/feeds.html"><img src="/prj/images/darpan-logo.png"  /> Home</a></li>'
    +'      <li class="projects" class="dropdown"><a class="dropdown-toggle projects"'
    +'   data-toggle="dropdown" href="#"><span class="projects">Projects</span></a>'
    +'          <ul class="dropdown-menu">'
    +'              <li><a href="/prj/pages/project/projectList.html">List</a></li>'
    +'              <li><a href="/prj/pages/project/createNewProject.html">Add new project</a></li>'
    +'          </ul>'
    +'      </li>'
    +'      <li class="training"><a href="#">Training</a></li>'

    + appraisalMenuHTML

    +'      <li class="recruitment"><a href="#">Recruitment</a></li>'
    +'      <li class="users" class="dropdown"><a class="dropdown-toggle users"'
    +'      data-toggle="dropdown" href="/prj/pages/user/userList.html"><span class="users">Users</span></a>'
    +'          <ul class="dropdown-menu">'
    +'              <li><a href="/prj/pages/user/userList.html">List</a></li>'
    +'              <li><a href="/prj/pages/user/createNewUser.html">Add new user</a></li>'
    +'          </ul>'
    +'      </li>'
    +'  </ul>'

    + userOptionsHTML

    +'</div>'
    +'</div>'
    +'</nav>';
    function darpanNav(selectedTab)
    alert('Object is : '+loggedInUser.toString());  
    theCompiledTemplate = navHTML.replace(""+selectedTab+"", "active")
    newRow = $("#nav-div").html(theCompiledTemplate);

HTML 文件是:

<!DOCTYPE html>
<html lang="en">
<head></head>
<body>
.
.
.
.
.
.

<script src="../js/prj.js"></script>

    <script src="/prj/js/navigation.js"></script>

    <script>
    darpanNav("feeds");

    </script>

</body>
</html>

注意:已包含所有必要的库和文件。所以不用担心。

现在我想要实现的是根据用户角色对来自文件navigation.js 的变量navHTML 的内容应用if-else 条件。也就是说,如果 roleId 为 2,那么我不想显示 appraisalMenuHTML 的内容,如果是 1,则显示它。

我应该如何做到这一点?

我在应用条件 od newHTML 时面临的问题是我无法访问修改后的全局变量 loggedInUser 值。这是我任务中的主要障碍。

有人请帮助我。

【问题讨论】:

你能创建一个 plunker 或 jsfiddle 【参考方案1】:

从我在prj.js中看到的,loggedInUser似乎属于全局范围,所以你应该可以在navigation.js中访问它,因为它是在prj.js之后调用的。但是请注意,在全局范围内包含任何内容并不是一个好习惯。

除非您有充分的理由从 javascript 文件创建模板(例如,如果您使用 React.js),否则您应该将其放置在实际的 html 文件中,并借助像 Jade 这样的模板引擎来制作逻辑。

【讨论】:

以上是关于我应该如何应用 if-else 条件来向具有不同用户角色的人显示不同的菜单?的主要内容,如果未能解决你的问题,请参考以下文章

if-else和三目运算符 ? : 的对比

我应该如何在 awk 中使用 if-else 语句?

case when then 根据不同条件 查询不同的数据 相当于 if-else if-else

如何分配每个用户在不同条件下访问项目?

if-else 中的块语句

过滤具有内部列表条件的列表