亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解Vue里循環(huán)form表單項(xiàng)實(shí)例

 更新時(shí)間:2021年09月08日 08:59:02   作者:廣漂的明哥  
本文主要介紹了Vue里循環(huán)form表單項(xiàng)實(shí)例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

有的時(shí)候我們可能會(huì)遇到這種需求,用戶點(diǎn)擊某個(gè)按鈕就可以增加一個(gè)同樣的表單出來(lái),點(diǎn)擊一次增加一次。然后要用到深拷貝,Vue.js+ElementUI等等。效果大概如下,就是一個(gè)表單有下拉框和兩個(gè)輸入框,現(xiàn)在點(diǎn)擊"添加表單"按鈕之后就會(huì)多一個(gè)表單出來(lái),點(diǎn)擊"提交表單"后就同時(shí)提交兩個(gè)表單的value值。

在這里插入圖片描述

代碼如下:

<template>
  <div>
    <div style="margin: 10px 0">
      <el-button type="primary" @click="addForm">添加表單</el-button>
      <el-button type="primary" @click="submit">提交表單</el-button>
    </div>
    <div v-for="(item, index) in List" :key="index">
      <el-form ref="form" label-width="80px">
        <el-form-item label="直播平臺(tái)">
          <el-select
            v-model="item.platform"
            :key="index"
            placeholder="請(qǐng)選擇直播平臺(tái)"
          >
            <el-option
              :label="item2.platformName"
              v-for="(item2, index2) in platformNameList"
              :key="index2"
              :value="item2.platformValue"
            >
            </el-option>
          </el-select>
        </el-form-item>

        <el-form-item label="粉絲量">
          <el-input v-model="item.fanMount" :key="index"></el-input>
        </el-form-item>

        <el-form-item label="平臺(tái)ID">
          <el-input v-model="item.platformId" :key="index"></el-input>
        </el-form-item>
      </el-form>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      title: "巡查內(nèi)容頁(yè)",
      personObj: {
        platform: "",
        fanMount: "",
        platformId: "",
      },
      platformNameList: [
        {
          platformName: "快手",
          platformValue: "1",
        },
        {
          platformName: "抖音",
          platformValue: "2",
        },
        {
          platformName: "淘寶",
          platformValue: "3",
        },
      ],
      List: [
        {
          platform: "",
          fanMount: "",
          platformId: "",
        },
      ],
    };
  },

  methods: {
  //深拷貝
    cloneObj(obj) {
      let ret;
      if (Array.isArray(obj)) {
        //創(chuàng)建一個(gè)空數(shù)組
        ret = [];
        for (let i = 0; i < obj.length; i++) {
          ret[i] = this.cloneObj(obj[i]);
        }
        return ret;
      } else if (Object.prototype.toString.call(obj) === "[object Object]") {
        ret = {};
        for (let i in obj) {
          ret[i] = this.cloneObj(obj[i]);
        }
        return ret;
      } else {
        return obj;
      }
    },
    //添加表單
    addForm() {
      let arr = this.cloneObj(this.personObj);
      console.log("arr", arr);
      this.List.push(arr);
    },
    //提交表單
    submit() {
      console.log("this.List", this.List);
    },
  },
};
</script>

代碼分析:
這里封裝了一個(gè)深拷貝函數(shù),每次點(diǎn)擊添加表單時(shí)就會(huì)拷貝一份我們定義好的對(duì)象,注意這個(gè)對(duì)象是由我們初始表單的value值組合起來(lái)的,我們?cè)谧钔鈱佑胿-for遍歷數(shù)組List然后每次點(diǎn)擊"添加表單"就往數(shù)組里push一個(gè)對(duì)象,最后點(diǎn)擊"提交表單"按鈕,打印this.List就能看到整個(gè)的數(shù)組對(duì)象了,我們來(lái)試一下,選擇輸入以下值:

在這里插入圖片描述

控制臺(tái)打印看下效果:

在這里插入圖片描述

現(xiàn)在假如說有個(gè)需求是,指定添加幾項(xiàng)表單,而不是點(diǎn)一次加一次表單,效果如下,有三個(gè)按鈕,最開始顯示一個(gè)表單

在這里插入圖片描述

當(dāng)我點(diǎn)擊"3個(gè)"按鈕的時(shí)候,界面總共有三個(gè)表單,如下圖:

在這里插入圖片描述

代碼如下:

<template>
  <div>
    <div style="margin: 10px 0">
      <el-button type="primary" @click="add(3)">3個(gè)</el-button>
      <el-button type="primary" @click="addForm">添加表單</el-button>
      <el-button type="primary" @click="submit">提交表單</el-button>
    </div>
    <div v-for="(item, index) in List" :key="index">
      <el-form ref="form" label-width="80px">
        <el-form-item label="直播平臺(tái)">
          <el-select
            v-model="item.platform"
            :key="index"
            placeholder="請(qǐng)選擇直播平臺(tái)"
          >
            <el-option
              :label="item2.platformName"
              v-for="(item2, index2) in platformNameList"
              :key="index2"
              :value="item2.platformValue"
            >
            </el-option>
          </el-select>
        </el-form-item>

        <el-form-item label="粉絲量">
          <el-input v-model="item.fanMount" :key="index"></el-input>
        </el-form-item>

        <el-form-item label="平臺(tái)ID">
          <el-input v-model="item.platformId" :key="index"></el-input>
        </el-form-item>
      </el-form>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      title: "巡查內(nèi)容頁(yè)",
      personObj: {
        platform: "",
        fanMount: "",
        platformId: "",
      },
      platformNameList: [
        {
          platformName: "快手",
          platformValue: "1",
        },
        {
          platformName: "抖音",
          platformValue: "2",
        },
        {
          platformName: "淘寶",
          platformValue: "3",
        },
      ],
      List: [
        {
          platform: "",

          fanMount: "",
          platformId: "",
        },
      ],
    };
  },

  methods: {
    cloneObj(obj) {
      let ret;
      if (Array.isArray(obj)) {
        //創(chuàng)建一個(gè)空數(shù)組
        ret = [];
        for (let i = 0; i < obj.length; i++) {
          ret[i] = this.cloneObj(obj[i]);
        }
        return ret;
      } else if (Object.prototype.toString.call(obj) === "[object Object]") {
        ret = {};
        for (let i in obj) {
          ret[i] = this.cloneObj(obj[i]);
        }
        return ret;
      } else {
        return obj;
      }
    },
    add(a) {
      this.addForm(a);
    },
    addForm(a) {
      let arr = this.cloneObj(this.personObj);
      console.log("arr", arr);
      this.List.push(arr);
      a--;
      if (a > 0) {
        this.addForm(a - 1);
      }
    },
    submit() {
      console.log("this.list", this.List);
    },
  },
};
</script>

<style>
</style>

代碼分析如下:

點(diǎn)擊按鈕的add方法的時(shí)候傳入總共的表單個(gè)數(shù),然后在添加表單的方法addForm里用了自減和判斷、遞歸來(lái)實(shí)現(xiàn)連續(xù)點(diǎn)擊時(shí)的拷貝等。然后我們?cè)囈幌滦Ч?br />

在這里插入圖片描述

控制臺(tái)打印看一下

在這里插入圖片描述

到此這篇關(guān)于詳解Vue里循環(huán)form表單項(xiàng)實(shí)例的文章就介紹到這了,更多相關(guān)Vue循環(huán)form表單項(xiàng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue axios sessionID每次請(qǐng)求都不同的原因以及修改方式

    vue axios sessionID每次請(qǐng)求都不同的原因以及修改方式

    這篇文章主要介紹了vue axios sessionID每次請(qǐng)求都不同的原因以及修改方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • 淺析vue中的provide / inject 有什么用處

    淺析vue中的provide / inject 有什么用處

    這篇文章主要介紹了vue中的provide / inject 有什么用處,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-11-11
  • vue+freemarker中遇到的坑及解決

    vue+freemarker中遇到的坑及解決

    這篇文章主要介紹了vue+freemarker中遇到的坑及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Vue按時(shí)間段查詢數(shù)據(jù)組件使用詳解

    Vue按時(shí)間段查詢數(shù)據(jù)組件使用詳解

    這篇文章主要為大家詳細(xì)介紹了Vue按時(shí)間段查詢數(shù)據(jù)組件的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • VueJs中如何使用Teleport及組件嵌套層次結(jié)構(gòu)詳解

    VueJs中如何使用Teleport及組件嵌套層次結(jié)構(gòu)詳解

    這篇文章主要為大家介紹了VueJs中如何使用Teleport及組件嵌套層次結(jié)構(gòu)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • vue3.2自定義彈窗組件結(jié)合函數(shù)式調(diào)用示例詳解

    vue3.2自定義彈窗組件結(jié)合函數(shù)式調(diào)用示例詳解

    這篇文章主要為大家介紹了vue3.2自定義彈窗組件結(jié)合函數(shù)式調(diào)用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • 基于Vue2.0+ElementUI實(shí)現(xiàn)表格翻頁(yè)功能

    基于Vue2.0+ElementUI實(shí)現(xiàn)表格翻頁(yè)功能

    Element UI 是一套采用 Vue 2.0 作為基礎(chǔ)框架實(shí)現(xiàn)的組件庫(kù),它面向企業(yè)級(jí)的后臺(tái)應(yīng)用,能夠幫助你快速地搭建網(wǎng)站,極大地減少研發(fā)的人力與時(shí)間成本。這篇文章主要介紹了Vue2.0+ElementUI實(shí)現(xiàn)表格翻頁(yè)功能,需要的朋友可以參考下
    2017-10-10
  • vue路由監(jiān)聽的一些常用方式

    vue路由監(jiān)聽的一些常用方式

    有時(shí)在頁(yè)面刷新或者返回等操作時(shí),想監(jiān)聽路由變化進(jìn)行數(shù)據(jù)更新等操作,下面這篇文章主要給大家介紹了關(guān)于vue路由監(jiān)聽的一些常用方式,需要的朋友可以參考下
    2023-10-10
  • vue頁(yè)面使用多個(gè)定時(shí)器的方法

    vue頁(yè)面使用多個(gè)定時(shí)器的方法

    這篇文章主要為大家詳細(xì)介紹了vue頁(yè)面使用多個(gè)定時(shí)器的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • vue簡(jiǎn)單的store詳解

    vue簡(jiǎn)單的store詳解

    這篇文章主要介紹了詳解vue簡(jiǎn)單的store,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-10-10

最新評(píng)論