我有以下数据,我希望判断用户是否具有管理员角色.

{
    "users": [
      {
        "id": 3,
        "first_name": "Joe",
        "last_name": "Blogs",
        "roles": [
          {
            "id": 1,
            "name": "Admin",
            "created_at": "2015-12-25 15:58:28",
            "updated_at": "2015-12-25 15:58:28",
            "pivot": {
              "user_id": 3,
              "role_id": 1,
              "created_at": "2015-12-25 16:03:09",
              "updated_at": "2015-12-25 16:03:09"
            }
          },
          {
            "id": 2,
            "name": "Member",
            "created_at": "2015-12-25 15:58:28",
            "updated_at": "2015-12-25 15:58:28",
            "pivot": {
              "user_id": 3,
              "role_id": 2,
              "created_at": "2015-12-25 16:03:09",
              "updated_at": "2015-12-25 16:03:09"
            }
          }
        ],
      }
    ]
  } 

在我的html中,我有以下内容,但如何使用v-if指令判断用户是否具有管理员角色?另一个问题是,如果条件不真实,下面的v-if指令也会生成不必要的html标记.

    <tr>
        <th>User</th>
        <th>Admin</th>
        <th></th>
    </tr>
    <tr v-for="user in users">
          <td>
               @{{user.first_name}} @{{user.last_name}}
          </td>
          <td>
              <span v-for="role in user.roles">
                   <span v-if="role.name" == 'Admin'>Yes</span>
                   <span v-else>-</span>
              </span>
          </td>
    </tr>

推荐答案

你的html有语法问题,应该是:

<span v-for="role in user.roles">
    <span v-if="role.name == 'Admin'">Yes</span>
    <span v-else>-</span>
</span>

不过,对于用户拥有的每个角色,您仍将有额外的跨度.

使用方法判断用户是否具有管理员角色更简单,这样您就不会有额外的html:

<div id="container">
  <table>
    <tr>
      <th>User</th>
      <th>Admin</th>
      <th></th>
    </tr>
    <tr v-for="user in users">
      <td>
        {{user.first_name}} {{user.last_name}}
      </td>
      <td>
        {{isAdmin(user)}}
      </td>
    </tr>
  </table>
</div>

还有javascript:

new Vue({
  el: '#container',
  data: {
    "users": [{
      "id": 3,
      "first_name": "Joe",
      "last_name": "Blogs",
      "roles": [{
        "id": 1,
        "name": "Admin",
        "created_at": "2015-12-25 15:58:28",
        "updated_at": "2015-12-25 15:58:28",
        "pivot": {
          "user_id": 3,
          "role_id": 1,
          "created_at": "2015-12-25 16:03:09",
          "updated_at": "2015-12-25 16:03:09"
        }
      }, {
        "id": 2,
        "name": "Member",
        "created_at": "2015-12-25 15:58:28",
        "updated_at": "2015-12-25 15:58:28",
        "pivot": {
          "user_id": 3,
          "role_id": 2,
          "created_at": "2015-12-25 16:03:09",
          "updated_at": "2015-12-25 16:03:09"
        }
      }],
    }]
  },
  methods: {
    isAdmin: function(user) {
      var i;
      for (i = 0; i < user.roles.length; i++) {
        if (user.roles[i].name === "Admin") {
          return "Yes";
        }
      }

      return "-";
    }
  }
});

这里的工作示例:https://jsfiddle.net/gmsa/t56oo4tw/

Vue.js相关问答推荐

在VITE-VUE APP-DEV模式上重定向HTTP请求

将 html 文件移出 dist vite 中的 src 文件夹

在 v-for 中定义变量有什么问题吗?

Vuetify/Nuxt 生产环境组件在开发环境中无法正常工作

为什么我在 Vue npm run serve 的 localhost 中得到无法获取

将函数作为属性传递给 Vue 组件

使用 Vue.js 和 Jest 进行 URL 重定向测试

vuejs vue-cli 如何使用 console.log 而不会出现任何错误

如何将 vue.js 与 gulp 一起使用?

如何根据生产或开发模式读取不同的 .env 文件?

在 vuejs 中将旧代码修改为 vue router 4

如何在 Node.js 服务器上部署 Vue.js 应用程序

如何告诉 Vue 应用使用 Firebase 模拟器?

如何使用 Vuejs 和 Laravel 获取当前经过身份验证的用户 ID?

使用 vue-router 的默认子路由

基本 vue.js 2 和 vue-resource http 获取变量赋值

Vuejs - 使用 v-if 切换的保持活动组件

如何从方法内部访问数据

将 ref 的内容从子组件传递到另一个 VueJS 子组件

如何在布局中使用组件?