欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue+elementUI實(shí)現(xiàn)動(dòng)態(tài)展示列表的數(shù)據(jù)

 更新時(shí)間:2022年08月15日 09:51:29   作者:吳小花的博客  
這篇文章主要介紹了Vue+elementUI實(shí)現(xiàn)動(dòng)態(tài)展示列表的數(shù)據(jù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Vue elementUI動(dòng)態(tài)展示列表的數(shù)據(jù)

需求描述

活動(dòng)查看的時(shí)候,根據(jù)后臺(tái)返回的數(shù)據(jù),動(dòng)態(tài)渲染列和每行數(shù)據(jù)。

后臺(tái)返回的數(shù)據(jù)結(jié)構(gòu)如下

html

    <!-- 彈出的查看數(shù)據(jù) -->
    <el-dialog
      width="1200px"
      :title="activityName"
      :visible.sync="viewDataPopUp"
    >
      <div class="export">
        <el-button type="primary" @click="exportData">導(dǎo)出數(shù)據(jù)</el-button>
      </div>
 
      <el-table border style="width: 100%" :data="resultTable" id="table">
        <!-- 循環(huán)問(wèn)題與答案 -->
        <el-table-column
          :label="item.label"
          :prop="item.prop"
          v-for="(item, key) in result"
          :key="key"
        >
        </el-table-column>
      </el-table>
    </el-dialog>

data定義需要用到的字段

      activitySettingPopUp: false, //活動(dòng)設(shè)置彈窗
      activityData: [], //查看活動(dòng)數(shù)據(jù)
      // answer: [],
      // tableAnswer: [],
      resultTable: [], //查看數(shù)據(jù)處理后的數(shù)據(jù)
      result: [], //查看數(shù)據(jù)用于循環(huán)的數(shù)據(jù)
      activityName: "", //查看數(shù)據(jù)的活動(dòng)名稱

調(diào)接口,成功后,將data.answers的值賦值給activityData.

        if (res.status_code === 200) {
            console.log(res);
            this.activityName = res.data.active_name;
            this.activityData = res.data.answers;
 
            this.result = this.getCol(this.activityData);
            this.resultTable = this.getTable(this.activityData);
          }

getCol方法獲取需要循環(huán)的列l(wèi)abel和值prop

    getCol(src) {
      let col = [];
      // for (let i = 0; i < src.length; i++) {
      for (let j in src[0]) {
        if (j === "answer") {
          let str = src[0][j];
          let str2obj = JSON.parse(str);
          for (let k in str2obj) {
            col.push({
              prop: k,
              label: str2obj[k]["title"],
            });
          }
        } else {
          col.push({
            prop: j,
            label: src[0][j].title,
          });
        }
      }
      // }
      return col;
    },
 

獲取表格的數(shù)據(jù)

    getTable(src) {
      let table = [];
      for (let i = 0; i < src.length; i++) {
        let temp = {};
        for (let j in src[i]) {
          if (j == "answer") {
            let obj = JSON.parse(src[i][j]);
            for (let k in obj) {
              temp[k] = obj[k].value;
            }
          } else {
            temp[j] = src[i][j].value;
          }
        }
        table.push(temp);
      }
      return table;
    },

Vue elementUI注意事項(xiàng)

多選框?qū)?yīng)List<object>

<el-select v-model="addOrEdit.obj" clearable multiple collapse-tags filterable value-key="id" style="width: 100%">
<el-option v-for="item in objList" :key="item.id" :label="item.name" :value="item"></el-option></el-select>

1.el-select標(biāo)簽

這個(gè)標(biāo)簽里對(duì)應(yīng)的就是后臺(tái)發(fā)過(guò)來(lái)的數(shù)據(jù)格式

如果后臺(tái)發(fā)來(lái)的數(shù)據(jù)是List<String>,即["1", "2", "3"]這種格式,則這個(gè)標(biāo)簽里value-key="id"就可以不用加了,重點(diǎn)在于el-option標(biāo)簽的key與其對(duì)應(yīng)就可以了

如果后臺(tái)數(shù)據(jù)是List<object>,即[{"id": "1", "name": "一"}, {"id": "2", "name": "二"}, {"id": "3", "name": "三"}]這種格式,那么就要加上value-key="id",將list<object> 里的對(duì)象的key與el-option里的objList的key對(duì)應(yīng)

2.el-option標(biāo)簽

  • key,就是用來(lái)用來(lái)作為標(biāo)識(shí)對(duì)應(yīng)的
  • label,就是用來(lái)前端展示內(nèi)容的
  • value,是選完之后向后端傳遞數(shù)據(jù)的,如果填的是item.id那么傳出的數(shù)據(jù)就只有id的數(shù)組,如果是item的話會(huì)將整個(gè)結(jié)構(gòu)傳出

輸入框判斷條件

1.格式判斷

只能輸入數(shù)字和兩位小數(shù)

rules: {
        num: { pattern: /(^[1-9]([0-9]+)?(\.[0-9]{1,2})?$)|(^(0){1}$)|(^[0-9]\.[0-9]([0-9])?$)/, message: '請(qǐng)輸入正確額格式,可保留兩位小數(shù)' }
      }

只能輸入數(shù)字

可以直接在el-input 標(biāo)簽內(nèi)加上 οnkeyup="value=value.replace(/[^\d]/g,'')" 即可

2.使用方法加入輸入框格式判斷數(shù)字和兩位小數(shù)

入?yún)ey即為addOrEdit這個(gè)數(shù)組里面的字段名

在el-input 標(biāo)簽內(nèi)加入:change="check_price('name')"即可

check_price(key) {
      var price = '' + this.addOrEdit[key];
      price = price
        .replace(/[^\d.]/g, '') // 清除“數(shù)字”和“.”以外的字符
        .replace(/\.{2,}/g, '.') // 只保留第一個(gè). 清除多余的
        .replace(/^\./g, '') //保證第一個(gè)為數(shù)字而不是.
        .replace('.', '$#$')
        .replace(/\./g, '')
        .replace('$#$', '.')
        .replace(/^(\-)*(\d+)\.(\d\d).*$/, '$1$2.$3'); // 只能輸入兩個(gè)小數(shù)
      if (price.indexOf('.') < 0 && price != '') {
        // 以上已經(jīng)過(guò)濾,此處控制的是如果沒有小數(shù)點(diǎn),首位不能為類似于 01、02的金額
        price = parseFloat(price);
      }
      this.$set(this.addOrEdit, key, price);
    },

3.提交判斷

即使加上以上判斷后輸入框提示了,但是如果提交的處理沒進(jìn)行判斷的話還是可以提交而導(dǎo)致后端出錯(cuò)。

所以當(dāng)點(diǎn)擊提交時(shí),應(yīng)將下面的addOrEdit替換為所需數(shù)組名稱,如果通過(guò)再執(zhí)行提交的邏輯

this.$refs['addOrEdit'].validate((valid) => {
    if (valid) {
        //執(zhí)行邏輯
   }
}

自定義彈窗格式

1.const h = this.$createElement;

新建一個(gè)html內(nèi)容的容器

2.this.$msgbox({}).then(() => {}).catch((err) => {});

用來(lái)新建一個(gè)彈窗

handleDelete(row) {
      const h = this.$createElement;
      this.$msgbox({
        title: '刪除',
        showCancelButton: true,
        confirmButtonText: '確定',
        cancelButtonText: '取消',
        iconClass: 'el-icon-circle-close',
        customClass: 'mes-width',
        message: h('div', { class: 'mr1' }, [h('p', { class: 'mes-d' }, '確定要?jiǎng)h除此項(xiàng)嗎?')])
      })
        .then(() => {
          deleteRule(row.id)
            .then((res) => {
              if (res.data.code === '1') {
                this.$message({
                  type: 'success',
                  message: '執(zhí)行成功!'
                });
                this.getRuleList();
              }
            })
            .catch((err) => {
              this.$message({
                type: 'warning',
                message: err
              });
            });
        })
        .catch((err) => {});
    },

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • VUE element上傳動(dòng)態(tài)設(shè)置action路徑和參數(shù)的坑及解決

    VUE element上傳動(dòng)態(tài)設(shè)置action路徑和參數(shù)的坑及解決

    這篇文章主要介紹了VUE element上傳動(dòng)態(tài)設(shè)置action路徑和參數(shù)的坑及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • vue.js源代碼core scedule.js學(xué)習(xí)筆記

    vue.js源代碼core scedule.js學(xué)習(xí)筆記

    這篇文章主要為大家詳細(xì)介紹了vue.js源代碼core scedule.js的學(xué)習(xí)筆記,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • vue 實(shí)現(xiàn)無(wú)規(guī)則截圖

    vue 實(shí)現(xiàn)無(wú)規(guī)則截圖

    這篇文章主要介紹了vue 實(shí)現(xiàn)無(wú)規(guī)則截圖的方法,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下
    2021-04-04
  • Vue導(dǎo)入excel文件的兩種方式(form表單和el-upload)

    Vue導(dǎo)入excel文件的兩種方式(form表單和el-upload)

    最近開發(fā)遇到一個(gè)點(diǎn)擊導(dǎo)入按鈕讓excel文件數(shù)據(jù)導(dǎo)入的需求,下面這篇文章主要給大家介紹了關(guān)于Vue導(dǎo)入excel文件的兩種方式,分別是form表單和el-upload兩種方法,需要的朋友可以參考下
    2022-11-11
  • 使用el-form-item設(shè)置標(biāo)簽長(zhǎng)度

    使用el-form-item設(shè)置標(biāo)簽長(zhǎng)度

    這篇文章主要介紹了使用el-form-item設(shè)置標(biāo)簽長(zhǎng)度方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue3 pinia踩坑及解決方案詳解

    vue3 pinia踩坑及解決方案詳解

    這篇文章主要為大家介紹了vue3 pinia踩坑及解決方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • 初識(shí) Vue.js 中的 *.Vue文件

    初識(shí) Vue.js 中的 *.Vue文件

    vue.js是一套構(gòu)建用戶界面的漸進(jìn)式框架,它采用自底向上增量開發(fā)的設(shè)計(jì).這篇文章主要介紹了VueJs 填坑日記之初識(shí) *.Vue文件,需要的朋友可以參考下
    2017-11-11
  • Vue使用Swiper的案例詳解

    Vue使用Swiper的案例詳解

    這篇文章主要介紹了Vue使用Swiper的案例詳解,主要包括引入swiper,創(chuàng)建輪播圖組件CarouselContainer.vue的詳細(xì)代碼,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • Vue組件解析之如何自定義彈窗組件ByDialog

    Vue組件解析之如何自定義彈窗組件ByDialog

    這篇文章主要介紹了Vue組件解析之如何自定義彈窗組件ByDialog問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 基于javascript的拖拽類封裝詳解

    基于javascript的拖拽類封裝詳解

    這篇文章主要介紹了基于javascript的拖拽類封裝,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04

最新評(píng)論