これで、親コンポーネント内でこの RecursiveRow コンポーネントを使用して、トップレベルのレイアウトを処理できるようになります。

それでおしまい。ご質問がございましたら、以下にコメントを残してください。

","image":"http://www.luping.net/uploads/20241022/17295566466716f0a64994b.png","datePublished":"2024-11-01T01:01:07+08:00","dateModified":"2024-11-01T01:01:07+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > 再帰コンポーネントを使用して Vue で動的レイアウトを生成する

再帰コンポーネントを使用して Vue で動的レイアウトを生成する

2024 年 11 月 1 日に公開
ブラウズ:574

この記事のインスピレーションは、Vue ベースのフロントエンドで動的レイアウトを構築するために私が行った最近の実装から来ています。

API エンドポイントが以下のような YAML レイアウトを返すと仮定します。


---
row:
  - col: 12
    row:
      - col: 12
        component_id: 1
  - col: 12
    row:
      - col: 6
        component_id: 2
      - col: 6
        row:
          - col: 12
            component_id: 3
          - col: 12
            component_id: 4


この YAML 式からは、次のようなレイアウトが期待されます。

Generating dynamic layouts in Vue using recursive components

それでは、この YAML 構造を解析して JSON オブジェクトを生成することで、作業が簡単になります。 yamlパッケージを使用しました。


npm install yaml



次に、それをインポートしてパーサーを実行します。


import YAML from 'yaml'
const jsonObject = YAML.parse(yaml_struct)


これを機能させるには、再帰的な Vue テンプレートと、ネストされた行に遭遇したときにそれ自体を再帰的に呼び出すことができるコンポーネントを作成する必要があります。このようにして、構造は、私が提供したような深くネストされたレイアウトを動的に処理します。


これで、親コンポーネント内でこの RecursiveRow コンポーネントを使用して、トップレベルのレイアウトを処理できるようになります。


それでおしまい。ご質問がございましたら、以下にコメントを残してください。

リリースステートメント この記事は次の場所に転載されています: https://dev.to/waruna/generated-dynamic-layouts-in-vue-using-recursive-components-4ci7?1 侵害がある場合は、削除するために[email protected]に連絡してください。それ
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3