在带有 JSON 的 Vue 组件中使用递归

Posted

技术标签:

【中文标题】在带有 JSON 的 Vue 组件中使用递归【英文标题】:Using recursion in a Vue component with JSON 【发布时间】:2018-08-13 18:20:51 【问题描述】:

我目前有一组通过 JSON 循环的嵌套模板。它输出键,检查值是否不是对象,如果不是对象则输出值,否则它会更深入并遍历该属性的内部对象/数组。它目前大约有 3 层深,但可能需要更深。

这使它成为递归的理想选择。我是前端语言/框架的新手,我很难找到好的资源来寻找如何使用 Vue 动态遍历 JSON 的好资源。 This was the best I could, but I'm not using predictable properties like label/node/nodes.

我想 Vue.component 模板是一个很好的起点。如何从主Vue实例传入JSON,然后如何设置模板动态遍历JSON?

HMTL

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Vue: Recursion</title>

  <!-- CDNs -->
  <script
  src="https://code.jquery.com/jquery-3.3.1.min.js"
  integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8="
  crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/vue@2.5.13/dist/vue.js"></script>

  <!-- JS -->
  <script src="app.js" charset="utf-8"></script>
</head>
<body>

  <main id="app">
    <template>
      <section>
        <recursive-component></recursive-component>
      </section>
    </template>
  </main>

</body>
</html>

javascript

$(function () 
  // Get JSON
  $.getJSON("./data.json", function (json) 
    app.json = json
  );


  Vue.component('recursive-component', function() 
    template: `
      <recursive-component
       v-if="node !== null"
       v-for="(node, key) in nodes"
       :nodes="node.nodes"
       :key="node.key"
       >
      </recursive-component>`
  );

  var app = new Vue(
    el: `#app`,
    data: 
      json: null
    
  );
);

通用 JSON


  "details": 
    "manufacturer": "BMW",
    "seats": 4,
    "engine": 
      "torque": 500,
      "hp": 600
    ,
    "breaks": 
      "front": 
        "type": "XYZ",
        "capacity": 1234
      
    
  

【问题讨论】:

您是说您有一些 json 数据,并且您想将这些数据“导入”到您的 Vue 实例中以便我们使用它吗? 我已经在 Vue 实例中拥有数据,其中 getJSON 函数设置了实例变量。我想知道如何构建一个递归模板来输出数据。 【参考方案1】:

解决方案的关键是检查数据是值还是对象,我在这个例子中假设值只是数字和字符串(因为检查变量是否是对象相当复杂***),然后递归组件只是相应地显示键/值。

const jsonData = 
  "details": 
    "manufacturer": "BMW",
    "seats": 4,
    "engine": 
      "torque": 500,
      "hp": 600
    ,
    "breaks": 
      "front": 
        "type": "XYZ",
        "capacity": 1234
      
    
  
;

Vue.component("my-recursive-component", 
  template: '#my-recursive-component',
  props: ["depth", "payload"],
  data() 
  ,
  computed: 
    indent() 
      return  transform: `translate($this.depth * 10px)` 
    ,
    type() 
      if (typeof this.payload === "string" || typeof this.payload === "number") 
        return "value";
      
      return "obj";
    ,
    list() 
      if (this.type === "obj") 
        return Object.keys(this.payload);
      
      return undefined;
    
  
);

const app = new Vue(
  el: "#app",
  data() 
    jsonData
  ,
);
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.5.13/vue.min.js"></script>

<div id="app">
  Recursive Component Demo:
  <my-recursive-component
    :payload="jsonData"
    :depth="0"
  >
  </my-recursive-component>
</div>

<script type="text/x-template" id="my-recursive-component">
  <div>
    <div 
      v-if="type === 'obj'" :style="indent">
      <div v-for="item in list">
        Key: item
        <my-recursive-component
          :payload="payload[item]"
          :depth="depth + 1"
          >
         <my-recursive-component/>
       </div>
    </div>
    <div 
      v-if="type === 'value'" :style="indent">
      Value: payload
    </div>
  </div>
</script>

【讨论】:

以上是关于在带有 JSON 的 Vue 组件中使用递归的主要内容,如果未能解决你的问题,请参考以下文章

vue递归遍历Json树状数据

vue组件递归——级联菜单的实现

Vue.js怎样把递归组件构建为树形菜单

vue递归组件

Vue 中的渲染函数和递归组件

Vue3_15(全局组件,局部组件,递归组件)