国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

ElementUI 樹形表格的使用以及表單嵌套樹形表格的校驗問題等匯總

這篇具有很好參考價值的文章主要介紹了ElementUI 樹形表格的使用以及表單嵌套樹形表格的校驗問題等匯總。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

目錄

一、樹形表格如何添加序號體現(xiàn)層級關(guān)系?

二、樹形表格展開收縮圖標(biāo)位置放置,設(shè)置指定列

三、表單嵌套樹形表格的校驗問題以及如何給校驗rules傳參

普通表格綁定如下:這種方法只能校驗表格的第一層,樹形需要遞歸設(shè)置子級節(jié)點prop。

樹形表格綁定如下:使用下面的方法(復(fù)制粘貼可以直接用)

四、樹形表格如何通過某屬性值進行過濾展示

1、可使用:row-style="tableRowClassName"去進行篩選 控制顯隱 這個方法比較簡單且不改變原treedata數(shù)據(jù)

2、過濾滿足屬性值需要的節(jié)點生成新的treedata數(shù)據(jù)來渲染表格


一、樹形表格如何添加序號體現(xiàn)層級關(guān)系?

實現(xiàn):treeData為表格數(shù)據(jù),遞歸調(diào)用getProjectIndex方法即可實現(xiàn);例如:1,1,1,1.2

<el-table-column label="序號" width="100" type="">
   <template slot-scope="scope">{{ scope.row.projectIndex }}</template>
</el-table-column>


//  添加索引
    addIndex() {
      this.treeData.forEach((node, i) => {
        this.getProjectIndex(node, '', i)
        // 默認(rèn)展開第一層
        this.expandKeys.push(node.id + '')
      })
    },
    // 獲取序號
    getProjectIndex(node, parentIndex, index) {
      const projectIndex = parentIndex ? `${parentIndex}.${index + 1}` : `${index + 1}`
      node.projectIndex = projectIndex
      if (node.children) {
        node.children.forEach((child, i) => {
          this.getProjectIndex(child, projectIndex, i)
        })
      }
    },

二、樹形表格展開收縮圖標(biāo)位置放置,設(shè)置指定列

在不需要的列前加上 ? type=""

<el-table-column label="序號" width="100" type="">
   <template slot-scope="scope">{{ scope.row.projectIndex }}</template>
</el-table-column>

三、表單嵌套樹形表格的校驗問題以及如何給校驗rules傳參

需求:一個樹形表格中每個樹節(jié)點都需要有日期范圍,想要校驗子節(jié)點的日期范圍不能超過父節(jié)點;

elementui樹狀表格,elementUI小課堂,vue.js,elementui,javascript

解決:如何綁定form的prop值?先了解如何綁定普通表格進行校驗

  1. 普通表格綁定如下:這種方法只能校驗表格的第一層,樹形需要遞歸設(shè)置子級節(jié)點prop。
     <template slot-scope="scope">
         <el-form-item :prop="`treeData.${scope.$index}.beginDate`" :rules="beginDateRules">
            <el-date-picker
               v-model="scope.row.beginDate"
               type="date"
               clearable
               format="yyyy-MM-dd"
               value-format="yyyy-MM-dd"
               placeholder="開始日期"
             />
         </el-form-item>
    </template>
  2. 樹形表格綁定如下:使用下面的方法(復(fù)制粘貼可以直接用)
findPosi(tree, targetId, path = '') {
      for (let i = 0; i < tree.length; i++) {
        const node = tree[i]
        if (node.id === targetId) {
          return path + i
        }
        if (node.children && node.children.length > 0) {
          const childPath = `${path}${i}.children.`
          const result = this.findPosi(node.children, targetId, childPath)
          if (result !== null) {
            return result
          }
        }
      }
      return null
    }

具體代碼實現(xiàn)如下:

//1、表單表格嵌套實現(xiàn)代碼 其余省略
<el-form ref="treeForm" :model="treeForm">
                <el-table
                  :data="treeForm.treeData"
                  row-key="id"
                  :row-style="tableRowClassName"
                  :expand-row-keys="expandKeys"
                  :tree-props="{ children: 'children'}"
                >
                  <el-table-column label="預(yù)計周期" width="310" align="center">
                    <template slot-scope="scope">
                      <el-form-item
                            :prop="'treeData.' + findPosi(treeForm.treeData,scope.row.id) + '.beginDate'"
                            :rules="beginDateRules(scope.row)"
                          >
                            <el-date-picker
                              v-model="scope.row.beginDate"
                              :style="{width: '100%'}"
                              type="date"
                              clearable
                              format="yyyy-MM-dd"
                              value-format="yyyy-MM-dd"
                              placeholder="開始日期"
                            />
                       </el-form-item>
                    </template>
                  </el-table-column>
                </el-table>
              </el-form>
//2、script標(biāo)簽內(nèi)容
//定義的數(shù)據(jù)格式
treeForm: {
  treeData: []
},
//方法調(diào)用 給rules傳參方式
beginDateRules(row) {
      return [
        { validator: (rule, value, callback) => { this.validateBeginDate(rule, value, callback, row) }, trigger: 'blur' }
      ]
    },
validateBeginDate(rule, value, callback, row) {
      // 沒有父節(jié)點不做判斷
      if (row.parentId === 0) {
        callback()
      } else {
        // 查找父節(jié)點
        const node = findParentId(this.treeForm.treeData, row.parentId)
        if (value && node.beginDate !== null) {
          if (new Date(value) < new Date(node.beginDate)) {
            callback(new Error('不能超過上一階段日期'))
          } else {
            callback()
          }
        } else {
          callback()
        }
      }
    },
//用到的工具類
// 1定義一個遞歸函數(shù),接受一個對象或數(shù)組,一個目標(biāo)id值和一個路徑數(shù)組作為參數(shù) 查找目標(biāo)id所在的路徑
    findPosi(tree, targetId, path = '') {
      for (let i = 0; i < tree.length; i++) {
        const node = tree[i]
        if (node.id === targetId) {
          return path + i
        }
        if (node.children && node.children.length > 0) {
          const childPath = `${path}${i}.children.`
          const result = this.findPosi(node.children, targetId, childPath)
          if (result !== null) {
            return result
          }
        }
      }
      return null
    }
//2通過節(jié)點id查找其父節(jié)點信息
/**
 * @param {*} tree
 * @param {*} targetId
 * @param {*} parentId
 * @returns
 * 通過節(jié)點id查找其父節(jié)點信息
 */
export function findParentId(tree, targetId) {
  for (const node of tree) {
    if (node.id === targetId) {
      return node
    }
    if (node.children) {
      const result = findParentId(node.children, targetId, node.id)
      if (result !== null) {
        return result
      }
    }
  }
  return null
}

四、樹形表格如何通過某屬性值進行過濾展示

1、可使用:row-style="tableRowClassName"去進行篩選 控制顯隱 這個方法比較簡單且不改變原treedata數(shù)據(jù)
tableRowClassName(data) {

? ? ? if (data.row.enabled === '0') {

? ? ? ? return { display: 'none' }

? ? ? }

? ? },
2、過濾滿足屬性值需要的節(jié)點生成新的treedata數(shù)據(jù)來渲染表格

原數(shù)據(jù) treeData:[] 新數(shù)據(jù):tree:[] 調(diào)用getenabledNodes()方法文章來源地址http://www.zghlxwxcb.cn/news/detail-667309.html

// 篩選選中節(jié)點
    getenabledNodes() {
      const tree = this.filterUnenabledNodes(this.treeData)
      console.log(tree)
    },
    filterUnenabledNodes(treeData) {
      const filteredData = []
      treeData.forEach(node => {
        if (node.enabled === '1') {
          filteredData.push(Object.assign({}, node, {
            children: node.children ? this.filterUnenabledNodes(node.children) : []
          }))
        }
      })
      return filteredData
    },

到了這里,關(guān)于ElementUI 樹形表格的使用以及表單嵌套樹形表格的校驗問題等匯總的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • element ui form表單循環(huán)嵌套 及嵌套表單item的校驗方法

    element ui form表單循環(huán)嵌套 及嵌套表單item的校驗方法

    html:? js:? 詳細(xì)的大家可以參考:element ui form循環(huán)嵌套表單 及嵌套表單的驗證方法(校驗)_element循環(huán)表單_RxnNing的博客-CSDN博客

    2024年02月09日
    瀏覽(27)
  • 關(guān)于uview小程序表單校驗不生效問題,以及小程序自定義校驗

    Form 表單 | uView - 多平臺快速開發(fā)的UI框架 - uni-app UI框架 官網(wǎng)例子 編寫完了之后發(fā)現(xiàn)正則這塊不生效 是因為不兼容,如果需要兼容小程序 需要加上 即可解決 如果校驗還沒生效請檢查標(biāo)簽是否填入必要的屬性

    2024年02月06日
    瀏覽(26)
  • ElementUI的Form表單使用slot-scope=“scope“獲取當(dāng)前表格行數(shù)據(jù)實現(xiàn)數(shù)據(jù)回顯、修改表單操作

    ElementUI的Form表單使用slot-scope=“scope“獲取當(dāng)前表格行數(shù)據(jù)實現(xiàn)數(shù)據(jù)回顯、修改表單操作

    在寫項目時,老師通過向后端發(fā)請求獲得表格原來的數(shù)據(jù)來填充修改表單里的數(shù)據(jù)。 這是表格: 這是點擊修改按鈕后顯示出來的修改表單: 但本地里都已經(jīng)有這些數(shù)據(jù)了,就沒必要再發(fā)一次請求,徒增服務(wù)器壓力。 準(zhǔn)備 可是該怎么獲得當(dāng)前行的數(shù)據(jù)填充上去呢?答案在

    2023年04月23日
    瀏覽(31)
  • elementUI 非表單格式的校驗

    elementUI 非表單格式的校驗

    ?在普通表單中對輸入框、選擇框都有校驗案例。 但是在自定義非空中如何進行校驗官網(wǎng)并沒有說明 關(guān)鍵代碼?clearValidate 方法清除校驗 使用案例

    2024年02月16日
    瀏覽(23)
  • vue表單及遍歷表單校驗rules以及validator校驗器的使用

    vue表單及遍歷表單校驗rules以及validator校驗器的使用

    為防止用戶犯錯,盡可能更早地發(fā)現(xiàn)并糾正錯誤。 Element中Form (表單)組件提供了表單驗證的功能,只需要通過 rules 屬性傳入約定的驗證規(guī)則,并將 Form-Item 的 prop 屬性設(shè)置為需校驗的字段名即可。 注意:prop對應(yīng)表單域 model 字段,使用 validate方法時,該屬性是必填的。 目

    2024年02月08日
    瀏覽(30)
  • elementUI 動態(tài)校驗表單數(shù)據(jù)的方法

    直接設(shè)置如下 list 為動態(tài)獲取的數(shù)據(jù)值列表數(shù)據(jù) 這里主要設(shè)置兩塊內(nèi)容 prop為動態(tài)數(shù)據(jù) rules設(shè)置需要校驗的值 :prop=“ list.${index}.title ” :rules=“rules.title” //title 名稱可自己定義

    2024年02月21日
    瀏覽(28)
  • element-ui的el-form表單和el-table校驗嵌套使用校驗el-input和el-select

    element-ui的el-form表單和el-table校驗嵌套使用校驗el-input和el-select

    場景:前端開發(fā)中,經(jīng)常會遇到比較多的表單填寫頁面,其中有el-form,el-table,表格的每一列中又嵌套著輸入框或者下拉框,然后每個還需要做單獨的校驗 效果: ? 點擊保存可校驗el-input和el-select是否有值,不符合校驗規(guī)則就標(biāo)紅提醒 ? 1.el-form里面嵌套el-table 2.在el-table-column自定義內(nèi)

    2024年02月02日
    瀏覽(32)
  • 解決ElementUI動態(tài)表單校驗驗證不通過

    解決ElementUI動態(tài)表單校驗驗證不通過

    這里記錄一下,寫項目時遇到的一個問題:就是動態(tài)渲染的表單項,加驗證規(guī)則后一直不通過!??! html部分: ?js部分: 結(jié)果:? ?可以看到,按照官網(wǎng)的寫法動態(tài)渲染的表單項是無法進行校驗驗證的。這里就是無論選中沒選中值都校驗 不通過。 修改prop、rules 結(jié)果:

    2024年02月12日
    瀏覽(21)
  • ElementUI 實現(xiàn)動態(tài)表單數(shù)據(jù)校驗(已解決)

    ElementUI 實現(xiàn)動態(tài)表單數(shù)據(jù)校驗(已解決)

    大家好很久沒有更新文章了,本片文章主要記錄一下遇到的問題, 使用element-ui開發(fā),el-form 表單驗證,由于表單的每一項是后端返回動態(tài)渲染的,之前只寫過靜態(tài)的表單驗證,網(wǎng)上查了一些資料和element的官方文檔最后得已解決,記錄下來分享給大家。 感興趣的小伙伴可以學(xué)

    2024年02月14日
    瀏覽(23)
  • vue +element UI form表單校驗數(shù)組嵌套,數(shù)組對象必填校驗

    vue +element UI form表單校驗數(shù)組嵌套,數(shù)組對象必填校驗

    使用element表單時會出現(xiàn)數(shù)組對象類型的數(shù)據(jù)結(jié)構(gòu)并且需要必填校驗 這時數(shù)組對象的檢驗方法就為paramJsonListRules 注意的是為了實現(xiàn)校驗,在需要校驗的el-form-item內(nèi)通過自己的:rules加入對象的校驗方法,例如圖中想給參數(shù)值加校驗則直接在相關(guān)el-form-item內(nèi)加入 :rules=\\\"paramJsonLis

    2024年02月11日
    瀏覽(30)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包