使用scope.row获取多层json数据

scope.row获取多层json数据

在写vue的一个页面时,后端传过来的json格式是这样的:

{
  "code": 200,
  "status": "OK",
  "message": "获取成功",
  "data": [
    {
      "id": 1,
      "name": "吴操作",
      "idCardNo": 351000200102031200,
      "role": {
        "id": 1,
        "name": "Demo Role",
        "authorities": [
          {
            "id": 1,
            "chineseName": "权限1"
          },
          {
            "id": 2,
            "chineseName": "权限2"
          }
        ]
      }
    }
  ]
}

想将role中的authorities的chineseName渲染到页面的表格中去,发现用scope.row常规办法不可行,获取到的还是authorities的全部json数据,经过尝试,以下方法可行:

<el-table-column label="角色名字" width="180">
                    <template slot-scope="scope">
                        <el-popover trigger="hover" placement="top" v-for="role in scope.row.roles">
                            <span v-for="role in scope.row.roles">
                                <span v-for="authority in role.authorities">
                                    <p>权限名称:{{ authority.chineseName }}</p>
                                </span>
                            </span>
                            <div slot="reference" class="name-wrapper">
                                <el-tag size="medium">{{ role.name }}</el-tag>
                            </div>
                        </el-popover>
                    </template>
                </el-table-column>

就是用v-for循环两次,取出authorities对象

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值