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

el-table樹形表格表單驗證(列表生成序號)

 更新時間:2020年05月31日 16:04:10   作者:j_bleach  
這篇文章主要介紹了el-table樹形表格表單驗證(列表生成序號),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

樹形表格表單驗證預覽

樹形列表生成序號

首先需要生成一個序號用來確定表單驗證的目標row,通過廣度優(yōu)先遍歷,以1,1.1,1.1.1的規(guī)則對樹形列表生成確定唯一值的索引,因為列表自身可以做CURD,因此需要每次列表的item增加或減少時重新調用生成索引的方法。

 setIndex = (data) => {
        let queue = [...data];
        let loop = 0;
        while (queue.length > 0) {
          loop++
          [...queue].forEach((child, i) => {
            queue.shift()
            if (loop == 1) {
              child.customIndex = i + 1 + "";
              child.currentIndex = i;
            }
            if (child.children && child.children.length > 0) {
              child.dataType = 1
              for (let ci = 0; ci < child.children.length; ci++) {
                child.children[ci].currentIndex = ci
                child.children[ci].customIndex = child.customIndex + "." + (ci + 1)
              }
              queue.push(...child.children)
            } else {
              child.dataType = 2
            }
          })
        }
      }
      const rows = [
        {
          id: "1",
          date: "2016-05-02",
          name: "王小虎1",
          address: "上海市普陀區(qū)金沙江路 1518 弄",
          children: [
            {
              name: "233",
              customIndex: "1.1",
              children: [{name: "9"}]
            },
            {
              name: "7771",
              customIndex: "1.2",
              children: [
                {
                  name: "9"
                }, 
                {
                  name: "9",
                }]
            }
          ]
        },
        {
          id: "2",
          date: "2016-05-04",
          name: "王小虎2",
          address: "上海市普陀區(qū)金沙江路 1517 弄",
          children: []
        },
       ]
 setIndex(rows)    

表單校驗

要想實現(xiàn)對表格的表單驗證,需要用form-item將整個表格包裹,然后在以子集的方式將每一列用form-item包裹。

 <el-form ref="form" :model="form" label-width="80px" :rules="rules">
      <el-form-item label-width="0" prop="rows">
        <el-table>
        </el-table>
      </el-form-item>
    </el-form>
<el-table-column
              prop="name"
              label="姓名"
              sortable
              width="180">
            <template v-slot="{$index, row}">
                           {{`rows${getPathByKey(row.customIndex,"customIndex",form.rows)}.name`}}
              <el-form-item label-width="0" :rules="rules.name"
                     :prop="`${row.customIndex!=='tempIndex'?`rows${getPathByKey(row.customIndex,'customIndex',form.rows)}.name`:''}`">
                <el-input v-model="row.name"></el-input>
              </el-form-item>
            </template>
          </el-table-column>

實現(xiàn)方式,表單校驗本質是對于目標數(shù)據(jù)的路徑查找,當el-form-item 上的prop匹配不到正確的目標是的時候就不能正常觸發(fā)校驗


因此,需要記錄每一個row上面的屬性路徑,即實現(xiàn)記錄每一行中屬性(name,address)路徑的方法。

 getPathByKey = (value, key, arr) => {
        let temppath = [];
        let realPath = ""
        try {
          function getNodePath(node) {
            temppath.push(node.currentIndex);
            //找到符合條件的節(jié)點,通過throw終止掉遞歸
            if (node[key] === value) {
              temppath.forEach((v, i) => {
                if (i == 0) {
                  realPath += "." + v
                } else {
                  realPath += `.children.${v}`
                }
              })
              // temppath = temppath.join(",")
              throw ("GOT IT!");
              // return;
            }
            if (node.children && node.children.length > 0) {
              for (var i = 0; i < node.children.length; i++) {
                getNodePath(node.children[i]);
              }

              //當前節(jié)點的子節(jié)點遍歷完依舊沒找到,則刪除路徑中的該節(jié)點
              temppath.pop();
            } else {

              //找到葉子節(jié)點時,刪除路徑當中的該葉子節(jié)點
              temppath.pop();
            }
          }

          for (let i = 0; i < arr.length; i++) {
            getNodePath(arr[i]);
          }
        } catch (e) {
          return realPath;
        }
      },

將每一列需要驗證的item,路徑查找好之后,form就可以具體監(jiān)控到所有的表格輸入,并觸發(fā)正確的驗證了,如圖:


demo參考

到此這篇關于el-table樹形表格表單驗證(列表生成序號)的文章就介紹到這了,更多相關el-table樹形表格表單驗證內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue動態(tài)路由配置及路由傳參的方式

    vue動態(tài)路由配置及路由傳參的方式

    這篇文章主要介紹了vue動態(tài)路由配置,vue路由傳參的方式,文中給大家提到了router-link這個組件的相關知識,需要的朋友可以參考下
    2018-05-05
  • 使用jenkins一鍵打包發(fā)布vue項目的實現(xiàn)

    使用jenkins一鍵打包發(fā)布vue項目的實現(xiàn)

    這篇文章主要介紹了使用jenkins一鍵打包發(fā)布vue項目的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-05-05
  • vue中使用jwt-decode解析token的方法

    vue中使用jwt-decode解析token的方法

    這篇文章主要介紹了vue中使用jwt-decode解析token,文末給大家補充介紹了vue通過jwt-decode解析token獲取需要的數(shù)據(jù),本文給大家介紹的非常詳細,需要的朋友可以參考下
    2022-06-06
  • vue-pdf實現(xiàn)文件在線預覽

    vue-pdf實現(xiàn)文件在線預覽

    這篇文章主要為大家詳細介紹了vue-pdf實現(xiàn)文件在線預覽,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 詳解vue 組件的實現(xiàn)原理

    詳解vue 組件的實現(xiàn)原理

    這篇文章主要介紹了詳解vue 組件的實現(xiàn)原理,幫助大家更好的理解和學習vue框架,感興趣的朋友可以了解下
    2020-11-11
  • 詳解Vue如何進行分布式事務管理以及解決方案

    詳解Vue如何進行分布式事務管理以及解決方案

    在分布式系統(tǒng)中,事務管理是一個非常重要的問題,所以本文將介紹一下Vue中如何進行分布式事務管理以及分布式事務解決方案,希望對大家有所幫助
    2023-06-06
  • vue cli2.0單頁面title修改方法

    vue cli2.0單頁面title修改方法

    這篇文章主要介紹了vue cli2.0單頁面title修改方法,非常不錯,具有一定的參考借鑒,需要的朋友可以參考下
    2018-06-06
  • vue el-date-picker 開始日期不能大于結束日期的實現(xiàn)代碼

    vue el-date-picker 開始日期不能大于結束日期的實現(xiàn)代碼

    這篇文章主要介紹了vue el-date-picker 開始日期不能大于結束日期的實現(xiàn)代碼,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-01-01
  • vue實現(xiàn)點擊按鈕倒計時

    vue實現(xiàn)點擊按鈕倒計時

    這篇文章主要為大家詳細介紹了vue實現(xiàn)點擊按鈕倒計時,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • vue使用transition組件動畫效果的實例代碼

    vue使用transition組件動畫效果的實例代碼

    這篇文章主要介紹了vue使用transition組件動畫效果的實例代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01

最新評論