How to check checkbox in vuetify when there is a data in the corresponding input when the edit button is click?

huangapple go评论49阅读模式
英文:

How to check checkbox in vuetify when there is a data in the corresponding input when the edit button is click?

问题

代码部分不要翻译,以下是要翻译好的内容:

要使复选框 (dataItem.OthersBox4) 在输入框(dataItem.OthersInput4)具有值或数据时选中,你可以在编辑项目的方法中添加条件来检查并设置该复选框的状态。在你的编辑方法中,你可以像这样操作:

async editItem(item) {
  this.itemIndex = this.items.indexOf(item);
  console.log(this.itemIndex);
  if (this.itemIndex > -1) {
    let datas = Object.assign({}, item);
    this.dataItem = datas;
    this.dataItem.firstNameBor = datas.firstname;
    this.dataItem.middleNameBor = datas.middleinitial;
    this.dataItem.lastNameBor = datas.lastname;
    this.dataItem.divisionBor = datas.division;
    this.dataItem.dateBor = datas.date;
    this.dataItem.purposeBor = datas.purpose;
    this.dataItem.borEquipments = datas.borrowed;
    this.dataItem.OthersInput4 = datas.others;

    // Check the checkbox if OthersInput4 has a value
    if (this.dataItem.OthersInput4) {
      this.dataItem.OthersBox4 = true;
    }

    this.itemId = datas.id;
    this.docRef = doc(borColRef, this.itemId);
    this.showDelete = true;
  }
  this.dialog = true;
}

在上面的代码中,我们在数据赋值后,检查了dataItem.OthersInput4是否有值,如果有值,就将dataItem.OthersBox4设置为true,以便选中复选框。这将确保在编辑时,如果输入框中有数据,相应的复选框会被选中。

英文:

|This is the Form|

   <v-form ref="formzz">
              <v-row class="mt-3">
                <v-col cols="12" sm="6" md="4">
                  <v-text-field label="First Name" hint="Input your first name" :rules="inputRule"
                    v-model="dataItem.firstNameBor" :prepend-inner-icon="userIcon" required outlined                                            dense
                    color="warning">
                  </v-text-field>
                </v-col>
                <v-col cols="12" sm="6" md="4">
                  <v-text-field label="Middle Initial" hint="Input your middle initial"
                    v-model="dataItem.middleNameBor" :prepend-inner-icon="userIcon" required outlined dense
                    color="warning" :rules="middleRule">
                  </v-text-field>
                </v-col>
                <v-col cols="12" sm="6" md="4">
                  <v-text-field label="Last Name" hint="Input your last name" v-model="dataItem.lastNameBor"
                    :prepend-inner-icon="userIcon" required outlined dense color="warning" :rules="inputRule">
                  </v-text-field>
                </v-col>
                <v-col cols="8">
                  <v-select :items="divisionsData" label="Choose Division" outlined v-model="dataItem.divisionBor"
                    dense color="warning" :rules="selectRule">
                  </v-select>
                </v-col>
                <v-col cols="4">
                  <v-menu ref="borMenu" v-model="borMenu" :close-on-content-click="false"
                    transition="scale-transition" offset-y max-width="290px" min-width="auto">
                    <template v-slot:activator="{ on, attrs }">
                      <v-text-field v-model="dataItem.dateBor" label="Date Borrowed" required outlined
                        :append-icon="dateIcon" dense hint="format: yyyy-mm-dd" v-bind="attrs" v-on="on"
                        color="warning" :rules="dateRule">
                      </v-text-field>
                    </template>
                    <v-date-picker v-model="dataItem.dateBor" @input="borMenu = false" color="warning">
                    </v-date-picker>
                  </v-menu>
                </v-col>

                <v-col cols="12">
                  <h4 class="text-start">Equipment/s to borrow:
                    <span v-if="!showCheckboxErrorMsg" class="text-caption red--text">Please select at least one
                      checkbox.</span>

                  </h4>
                  <div class="d-flex flex-row justify-space-between">
                    <v-checkbox label="Projector" value="Projector" v-model="dataItem.borEquipments"
                      color="warning">
                    </v-checkbox>
                    <v-checkbox label="Laptop" value="Laptop" v-model="dataItem.borEquipments" color="warning">
                    </v-checkbox>
                    <v-checkbox label="Microphone" value="Microphone" v-model="dataItem.borEquipments"
                      color="warning">
                    </v-checkbox>
                    <v-checkbox label="Document Reader" value="Document Reader" v-model="dataItem.borEquipments"
                      color="warning">
                    </v-checkbox>
                    <v-checkbox label="White Screen" value="White Screen" v-model="dataItem.borEquipments"
                      color="warning">
                    </v-checkbox>
                    <v-checkbox label="Extension Cord" value="Extension Cord" v-model="dataItem.borEquipments"
                      color="warning">
                    </v-checkbox>
                  </div>
                </v-col>
                <v-col cols="12">
                  <div class="d-flex flex-row justify-space-between align-center">
                    <v-checkbox color="warning" label="Others: " class="mb-6" value="Others"
                      v-model="dataItem.OthersBox4" name="InstallationBox" :checked="isOthersBoxChecked" >
                    </v-checkbox>
                    <!-- <v-text-field class="ml-4" hint="Please specify others to check/repair"
                      v-model="dataItem.OthersInput4" required outlined :disabled="!dataItem.OthersBox4" dense
                      color="warning" :rules="checkInputRule4">
                    </v-text-field> -->
                    <v-text-field class="ml-4" hint="Please specify others to check/repair"
                      v-model="dataItem.OthersInput4" required outlined :disabled="!dataItem.OthersBox4" dense
                      color="warning" :rules="checkInputRule4">
                    </v-text-field>
                  </div>
                </v-col>

                <v-col cols="12">
                  <div class="d-flex flex-row justify-space-between">
                    <v-textarea class="ml-4" label="Purpose" hint="Please specify your purpose" required
                      v-model="dataItem.purposeBor" outlined color="warning" :rules="inputRule"></v-textarea>
                  </div>
                </v-col>
              </v-row>
            </v-form>

|This is the edit item method

    async editItem(item) {

    this.itemIndex = this.items.indexOf(item);
    console.log(this.itemIndex)
    if (this.itemIndex > -1) {

      let datas = Object.assign({}, item);
      this.dataItem = datas
      this.dataItem.firstNameBor = datas.firstname;
      this.dataItem.middleNameBor = datas.middleinitial;
      this.dataItem.lastNameBor = datas.lastname;
      this.dataItem.divisionBor = datas.division;
      this.dataItem.dateBor = datas.date;
      this.dataItem.purposeBor = datas.purpose;
      this.dataItem.borEquipments = datas.borrowed;
      //console.log(this.dataItem.borEquipments)
      this.dataItem.OthersInput4 = datas.others;
      //console.log(datas.others)

      if(this.dataItem.OthersBox4){
        this.dataItem.OthersInput4 = true;
      
      }

      this.itemId = datas.id;
      this.docRef = doc(borColRef, this.itemId);
      this.showDelete = true;
    }
    this.dialog = true;
       },

It should check the checkbox of dataItem.OthersInput4 if there is a data. the checkbox has a v-model of dataItem.OthersBox4. When the edit button is clicked, it does not check the checkbox when it has data. There is only value with the corresponding input but the checkbox is not checked.

How do I make it check the checkbox (dataItem.OthersBox4) when the input(dataItem.OthersInput4) has value or data?

答案1

得分: 0

以下是您要翻译的内容:

  1. 从您的 v-checkbox 中删除 value="Others"
  2. 将其设置为 readonly
  3. 在您的复选框的 v-model 中使用以下计算值 OthersBox4

就像这样:

computed: {
    OthersBox4() {
        return this.OthersInput4?.length > 0;
    }
}

这是可用的工作示例:

<!-- 开始示例:js 隐藏: false 控制台: true Babel: false -->

<!-- 语言: lang-js -->

const { createApp } = Vue;
const { createVuetify } = Vuetify;

const App = {
  data() {
    return {
      OthersInput4: null
    }
  },
  computed: {
    OthersBox4() {
        return this.OthersInput4?.length > 0;
    }
  }
}

const vuetify = createVuetify();
const app = createApp(App);
app.use(vuetify);
app.mount('#app');

<!-- 语言: lang-css -->

#app { line-height: 3; }
[v-cloak] { display: none; }

<!-- 语言: lang-html -->

<link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/vuetify@3.1.4/dist/vuetify.min.css" />
<link href="https://cdn.jsdelivr.net/npm/@mdi/font@5.x/css/materialdesignicons.min.css" rel="stylesheet" />
<div id="app">
  <v-form ref="formzz">
      <v-row>
         <v-col>
            <v-checkbox v-model="OthersBox4" color="warning" label="Others: " class="mb-6"
             name="InstallationBox" readonly>
            </v-checkbox>
            <v-text-field class="ml-4" hint="Please specify others to check/repair"
              v-model="OthersInput4" required outlined  dense
              color="warning" :rules="checkInputRule4">
            </v-text-field>
        </v-col>     
      </v-row>
    </v-form>
</div>
<script src="https://unpkg.com/vue@3/dist/vue.global.prod.js"></script>
<script src="https://cdn.jsdelivr.net/npm/vuetify@3.1.4/dist/vuetify-labs.min.js"></script>

<!-- 结束示例 -->
英文:

Do following:

  1. remove value=&quot;Others&quot; from your v-checkbox
  2. make it readonly
  3. use the following computed value OthersBox4 in the v-model of your checkbox

Like this:

 computed: {
    OthersBox4() {
        return this.OthersInput4?.length &gt; 0;
    }
  }

Here is the working playground
<!-- begin snippet: js hide: false console: true babel: false -->

<!-- language: lang-js -->

const { createApp } = Vue;
const { createVuetify } = Vuetify;

const App = { 
  data() { 
    return {
      OthersInput4: null
    }
  },
  computed: {
    OthersBox4() {
        return this.OthersInput4?.length &gt; 0;
    }
  }
}

const vuetify = createVuetify();
const app = createApp(App);
app.use(vuetify);
app.mount(&#39;#app&#39;);

<!-- language: lang-css -->

#app { line-height: 3; }
[v-cloak] { display: none; }

<!-- language: lang-html -->

&lt;link rel=&quot;stylesheet&quot; type=&quot;text/css&quot; href=&quot;https://cdn.jsdelivr.net/npm/vuetify@3.1.4/dist/vuetify.min.css&quot; /&gt;
&lt;link href=&quot;https://cdn.jsdelivr.net/npm/@mdi/font@5.x/css/materialdesignicons.min.css&quot; rel=&quot;stylesheet&quot; /&gt;
&lt;div id=&quot;app&quot;&gt;
  &lt;v-form ref=&quot;formzz&quot;&gt;
      &lt;v-row&gt;
         &lt;v-col&gt;
            &lt;v-checkbox v-model=&quot;OthersBox4&quot; color=&quot;warning&quot; label=&quot;Others: &quot; class=&quot;mb-6&quot;
             name=&quot;InstallationBox&quot; readonly&gt;
            &lt;/v-checkbox&gt;
            &lt;v-text-field class=&quot;ml-4&quot; hint=&quot;Please specify others to check/repair&quot;
              v-model=&quot;OthersInput4&quot; required outlined  dense
              color=&quot;warning&quot; :rules=&quot;checkInputRule4&quot;&gt;
            &lt;/v-text-field&gt;
        &lt;/v-col&gt;     
      &lt;/v-row&gt;
    &lt;/v-form&gt;
&lt;/div&gt;
&lt;script src=&quot;https://unpkg.com/vue@3/dist/vue.global.prod.js&quot;&gt;&lt;/script&gt;
&lt;script src=&quot;https://cdn.jsdelivr.net/npm/vuetify@3.1.4/dist/vuetify-labs.min.js&quot;&gt;&lt;/script&gt;

<!-- end snippet -->

huangapple
  • 本文由 发表于 2023年4月11日 09:34:38
  • 转载请务必保留本文链接:https://go.coder-hub.com/75981821.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定