如何创建动态表单vuejs vuetify?

费利佩·科苏基(Felipe Kosouski)

我正在尝试制作一个动态表格来工作。我有一系列的能力,而在内部,我有一系列的技能。整个能力的每项技能都将得到评估,因此需要一个答案。

一切都以带有动态步骤的v-stepper进行组织,而我的表单字段是由v-for生成的。对于每种技能,答案都需要拥有,也许像

answers: [
  skillId:
  skillLevel:
  feedback:
  feedforward:
  ...
]

我的问题是,作为动态生成的表单,我该如何为每个字段设置v模型?由于能力可以具有许多技能,因此绑定模型需要有所不同。

这是我的代码

<template>
  <v-stepper v-model="e1" :appraisal="appraisal">
    <v-stepper-header>
      <template v-for="n in steps">
        <v-stepper-step :key="`${n}-step`" :step="n" :complete="e1 > n" editable></v-stepper-step>
        <v-divider v-if="n !== steps" :key="n"></v-divider>
      </template>
    </v-stepper-header>
    <v-stepper-items>
      <v-stepper-content v-for="n in steps" :key="`${n}-content`" :step="n">
        <v-row align="center" justify="center">
          <v-col cols="4">
            <v-subheader class="headline">{{appraisal.appraisalCompetences[n-1].competence.name}}</v-subheader>
          </v-col>
        </v-row>

        <v-row>
          <v-col cols="12">
            <v-row justify="center">
              <v-col cols="3">
                <v-subheader class="title">Fatores</v-subheader>
              </v-col>
              <v-col cols="2">
                <v-subheader class="title">Presença da competência</v-subheader>
              </v-col>
              <v-col cols="2">
                <v-subheader class="title">Feedback do Gestor</v-subheader>
              </v-col>
              <v-col cols="2">
                <v-subheader class="title">Auto Avaliação</v-subheader>
              </v-col>
              <v-col cols="3">
                <v-subheader class="title">Feedforward</v-subheader>
              </v-col>
            </v-row>
          </v-col>
        </v-row>
        <v-divider></v-divider>
        <template v-for="competence in appraisal.appraisalCompetences[n-1]">
          <v-form :key="`${competence.competenceId}-form`">
            <v-row v-for="(item, index) in competence.competenceSkills" :key="index">
              <v-col cols="12">
                <v-row class="mb-n10" justify="center">
                  <v-col cols="3" class="mt-4">
                    <span>{{item.skill.name}}</span>
                  </v-col>

                  <v-col cols="2">
                    <v-select
                      v-model="answers.skillLevel"
                      outlined
                      :items="selectLevels"
                      :name="`skill-level-${item.skill.skillId}`"
                      label="Selecione"
                      item-text="level"
                      item-value="value"
                    ></v-select>
                  </v-col>
                  <v-col cols="2">
                    <v-textarea outlined rows="3" :name="`skill-feedback-${item.skill.skillId}`"></v-textarea>
                  </v-col>
                  <v-col cols="2">
                    <v-textarea
                      outlined
                      rows="3"
                      :name="`skill-selfappraisal-${item.skill.skillId}`"
                    ></v-textarea>
                  </v-col>
                  <v-col cols="3">
                    <v-textarea outlined rows="3" :name="`skill-feedforward-${item.skill.skillId}`"></v-textarea>
                  </v-col>
                </v-row>
              </v-col>
            </v-row>
          </v-form>
        </template>
        <v-row>
          <v-col cols="12">
            <v-row align="center" justify="space-between">
              <v-btn tile large color="error" @click="previous(n)">
                <v-icon dark left>mdi-arrow-left</v-icon>Voltar
              </v-btn>

              <v-btn tile large color="success" @click="next(n)">
                Continuar
                <v-icon dark right>mdi-arrow-right</v-icon>
              </v-btn>
            </v-row>
          </v-col>
        </v-row>
      </v-stepper-content>
    </v-stepper-items>
  </v-stepper>
</template>
<script>
export default {
  data: () => ({
    e1: 1,
    steps: 1,
    appraisal: [],
    selectLevels: [
      { value: 0, level: "Ausente" },
      { value: 1, level: "A Desenvolver" },
      { value: 2, level: "Satifatória" },
      { value: 3, level: "Excelencia" },
      { value: 4, level: "Não se aplica" }
    ],
    answers: [
      {
        competenceId: "",
        appraisalId: "",
        skillId: "",
        skillLevel: "",
        feedback: "",
        selfAppraisal: "",
        feedforward: ""
      }
    ]
  }),
  created() {
    this.initialize();
  },
  methods: {
    initialize() {
      axios
        .get(`/questionnaire/appraisals/${this.$route.params.appraisalId}`)
        .then(response => {
          this.appraisal = response.data;
          this.steps = this.appraisal.appraisalCompetences.length;
        });
    },
    previous(n) {
      if (this.e1 == 1) {
        this.$router.push("/app/pdc");
      } else {
        this.e1 = n - 1;
      }
    },
    next(n) {
      if (n === this.steps) {
        this.e1 = 1;
      } else {
        this.e1 = n + 1;
      }
    }
  }
};
</script>

已编辑

让我尝试改善这个问题

以我的形式,对于每项能力,我都有一套将要评估的技能。因此,对于每种技能,我都需要有一个单独的答案,例如技能1

  skillId:
  skillLevel:
  feedback:
  feedforward:
  ...

其他所有技能,依此类推。在用户为能力中的每种技能键入答案后,我需要对能力2等进行相同的操作。问题在于表格的答案部分,我不知道如何将每一行都计为一个答案,然后将它们添加到答案数组中

这是我到目前为止提出的

<template v-for="competence in appraisal.appraisalCompetences[n-1]">
          <v-row v-for="(item, index) in competence.competenceSkills" :key="index">
            <v-col cols="12">
              <v-form :key="`${item.skillId}-form`">
                <v-row class="mb-n10" justify="center">
                  <v-col cols="3" class="mt-4">
                    <span>{{item.skill.name}}</span>
                  </v-col>

                  <v-col cols="2">
                    <v-select
                      v-model="`${item.skillId}-form`.skillLevel"
                      outlined
                      :items="selectLevels"
                      label="Selecione"
                      item-text="level"
                      item-value="value"
                    ></v-select>
                  </v-col>
                  <v-col cols="2">
                    <v-textarea v-model="answer.feedback" outlined rows="3"></v-textarea>
                  </v-col>
                  <v-col cols="2">
                    <v-textarea v-model="answer.selfAppraisal" outlined rows="3"></v-textarea>
                  </v-col>
                  <v-col cols="3">
                    <v-textarea v-model="answer.feedForward" outlined rows="3"></v-textarea>
                  </v-col>
                </v-row>
              </v-form>
            </v-col>
          </v-row>
        </template>
export default {
  data: () => ({
    e1: 1,
    steps: 1,
    appraisal: [],
    selectLevels: [
      { value: 0, level: "Ausente" },
      { value: 1, level: "A Desenvolver" },
      { value: 2, level: "Satifatória" },
      { value: 3, level: "Excelencia" },
      { value: 4, level: "Não se aplica" }
    ],
    answer: {
      competenceId: "",
      skillId: "",
      skillLevel: "",
      feedback: "",
      selfAppraisal: "",
      feedForward: ""
    },
    anwers: []
  }),
赛义德·汉顿

首先,有一些很好的vuejs-vuetify现成表单生成器,它基于标准的json-schema。

请参阅下面的示例和项目,特别是github代码,以获取有关如何创建好的表单生成器的更多详细信息和想法,以便可以使用它们。

https://github.com/koumoul-dev/vuetify-jsonschema-form

https://koumoul-dev.github.io/vuetify-jsonschema-form/latest/?example=basic

如果您想从头开始编写一些项目,则应该考虑一下这个想法很简单,例如在表中呈现内联编辑(通过对象传递使用引用):请参见以下示例: 在此处输入图片说明

注意逻辑,您应该正确地建立索引,当我调试代码时,代码始终会至少回答0到5。所以你不能使它工作。请仔细阅读以下内容以解决您的问题:

  <v-col cols="2">
                    <v-select
                      v-model="answers[index + (competence.competenceId-1)*competence.competenceSkills.length ].skillLevel"
                      outlined
                      :items="selectLevels"
                      label="Selecione"
                      item-text="level"
                      item-value="value"
                    ></v-select>
                  </v-col>
                  <v-col cols="2">
                    <v-textarea v-model="answers[index + (competence.competenceId-1)*competence.competenceSkills.length].feedBack" outlined rows="3"></v-textarea>
                  </v-col>
                  <v-col cols="2">
                    <v-textarea v-model="answers[index + (competence.competenceId-1)*competence.competenceSkills.length].selfAppraisal" outlined rows="3"></v-textarea>
                  </v-col>
                  <v-col cols="3">
                    <v-textarea v-model="answers[index + (competence.competenceId-1)*competence.competenceSkills.length].feedForward" outlined rows="3"></v-textarea>
                  </v-col>

或者您可以使用更好的主意,将答案分开,如下所示:

请参阅下文,了解我如何解决此问题的想法: 在此处输入图片说明 在此处输入图片说明

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

如何在vuejs中动态创建输入字段(vuetify)

来自分类Dev

如何为 v-select、vuetify、vuejs 设置动态值?

来自分类Dev

桌子的动态高度(Vuetify)

来自分类Dev

如何禁用Vuetify的样式?

来自分类Dev

如何 vuetify 动态生成的 vue 表?

来自分类Dev

如何创建嵌套的vuetify导航抽屉?

来自分类Dev

如何使 vuetify 扩展面板独奏?

来自分类Dev

Vuetify 2.0:如何从Vuetify 1.5实现这种布局?

来自分类Dev

如何组合 Vuetify 数据表和 Vuetify 列表?

来自分类Dev

如何查询VueJs / Vuetify当前是否在制作动画?

来自分类Dev

如何从 Vuetify 列表中的 Vuex 商店获取状态,VueJs

来自分类Dev

如何从 Vuetify 列表、VueJS 在 Vuex 商店中提交变更

来自分类Dev

Vuetify表单验证禁用项目

来自分类Dev

Vuetify 表单数据未定义

来自分类Dev

如何使vuetify v-stepper标头动态完成?

来自分类Dev

使用Vuetify进行动态计算

来自分类Dev

Vuetify v-select 动态填充/排序

来自分类Dev

使用Vuetify创建自定义图标

来自分类Dev

如何创建基于Vuetify的浏览器扩展?

来自分类Dev

如何使用Vuetify创建连续的v-slide-group?

来自分类Dev

如何创建Vuetify数据表的字体大小?

来自分类Dev

如何使用Composition API创建Vuetify加载按钮

来自分类Dev

如何在Vuetify中为激活器属性创建节点?

来自分类Dev

如何解决vuetify扩展面板的问题?

来自分类Dev

如何使用Vuetify反转标头方向?

来自分类Dev

如何在列表上设置Vuetify分页

来自分类Dev

如何使用vuetify v-rating事件?

来自分类Dev

如何从vuetify上的多个datepicker获取日期?

来自分类Dev

如何使用vuetify制作自适应网站?