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

vue3+elementPlus?table中添加輸入框并提交校驗

 更新時間:2024年05月31日 10:49:56   作者:再希  
這篇文章主要介紹了vue3+elementPlus?table里添加輸入框并提交校驗,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

<template>
  <div>
      <el-form :model="info" ref="forms">
          <el-table
          ref="tableRef"
          :data="info.data"
          border>
          <el-table-column align="center" property="name" label="*姓名">
              <template #default="row">
                  <el-form-item :prop="'data.' + row.$index + '.name'" :rules="formRules.name">
                      <el-input placeholder="請輸入姓名" v-model="info.data[row.$index].name" />
                  </el-form-item>
              </template>
          </el-table-column>
          <el-table-column align="center" property="role" label="角色">
              <template #default="row">
                  <el-form-item :prop="'data.' + row.$index + '.role'" :rules="formRules.role">
                      <el-input placeholder="請輸入角色" v-model="info.data[row.$index].role" />
                  </el-form-item>
              </template>
          </el-table-column>
          </el-table>
      </el-form>
    <el-button type="primary" @click="submitForm()">Submit</el-button>
  </div>
</template>
<script setup lang="ts">
import {ref, reactive} from 'vue'
import type { FormInstance } from 'element-plus'
let info:any = reactive({
  data:[
      {
      id: 0,
      name: '',
      role:''
      },{
        id: 1,
        name: '',
        role:''
      }
  ]
})
const formRules = reactive({
  name: [{ required: true, message: '請輸入姓名', trigger: 'change' }],
  role: [{ required: true, message: '請輸入角色', trigger: 'change' }]
})
const forms = ref<FormInstance>()
const submitForm = async () => {
  if (!forms) return
  return await forms.value?.validate((valid: any) => {
      if (valid) {
      console.log('submit!')
      } else {
      console.log('error submit!')
      return false
      }
  })
}
</script>

擴展:vue3+elementPlus table里添加輸入框并提交校驗

<template>
  <div style="display: flex; align-items: center">
    <h3 style="margin-right: 20px">成員信息</h3>
  </div>
  <el-form :model="info" ref="forms">
    <el-table
      :data="info.membersList"
      @selection-change="handleSelectionChange"
    >
      <el-table-column type="selection" width="55" />
      <el-table-column type="index" label="序號" width="55" />
      <el-table-column label="成員號碼" prop="userNumber">
        <template #default="row">
          <el-form-item
            :prop="'membersList.' + row.$index + '.userNumber'"
            :rules="formRules.userNumber"
          >
            <el-input
              placeholder="請輸入成員號碼"
              v-model="info.membersList[row.$index].userNumber"
            />
          </el-form-item>
        </template>
      </el-table-column>
      <el-table-column label="機頂盒側mac" prop="age">
        <template #default="row">
          <el-form-item
            :prop="'membersList.' + row.$index + '.macCode'"
            :rules="formRules.macCode"
          >
            <el-input
              placeholder="請輸入機頂盒側mac"
              v-model="info.membersList[row.$index].macCode"
            />
          </el-form-item>
        </template>
      </el-table-column>
      <el-table-column label="機頂盒stbid" prop="snCode">
        <template #default="row">
          <el-form-item
            :prop="'membersList.' + row.$index + '.snCode'"
            :rules="formRules.snCode"
          >
            <el-input
              placeholder="請輸入機頂盒stbid"
              v-model="info.membersList[row.$index].snCode"
            />
          </el-form-item>
        </template>
      </el-table-column>
      <el-table-column label="電視賬號" prop="tvAccount">
        <template #default="row">
          <el-form-item
            :prop="'membersList.' + row.$index + '.tvAccount'"
            :rules="formRules.tvAccount"
          >
            <el-input
              placeholder="請輸入電視賬號"
              v-model="info.membersList[row.$index].tvAccount"
            />
          </el-form-item>
        </template>
      </el-table-column>
      <el-table-column label="備注(如房間號)" prop="remark">
        <template #default="row">
          <el-form-item
            :prop="'membersList.' + row.$index + '.remark'"
            :rules="formRules.remark"
          >
            <el-input
              placeholder="請輸入備注(如房間號)"
              v-model="info.membersList[row.$index].remark"
            />
          </el-form-item>
        </template>
      </el-table-column>
      <el-table-column label="操作">
        <template #default="row">
          <el-form-item :prop="'membersList.' + row.$index + '.oprcode'">
            <el-select
              placeholder="請選擇操作類型"
              style="margin-right: 10px"
              v-model="info.membersList[row.$index].oprcode"
            >
              <el-option label="添加" value="01" />
              <el-option label="刪除" value="02" />
            </el-select>
          </el-form-item>
        </template>
      </el-table-column>
    </el-table>
  </el-form>
</template>
<script setup name="index" lang="ts">
  import {
    Search,
    Plus,
    Upload,
    Minus,
    Download,
  } from '@element-plus/icons-vue'
  import type { FormInstance } from 'element-plus'
  const { proxy } = getCurrentInstance()
  let info: any = reactive({
    membersList: [],
  })
  const formRules = reactive({
    userNumber: [
      { required: true, message: '請輸入成員號碼', trigger: 'blur' },
    ],
    macCode: [
      { required: true, message: '請輸入機頂盒側mac', trigger: 'blur' },
    ],
    snCode: [{ required: true, message: '請輸入機頂盒stbid', trigger: 'blur' }],
  })
  const forms = ref<FormInstance>()
  const save = async () => {
    if (!forms) return
    await forms.value?.validate((valid: any) => {
      if (valid) {
      }
    })
  }
</script>

到此這篇關于vue3+elementPlus table里添加輸入框并提交校驗的文章就介紹到這了,更多相關vue3 elementPlus table輸入框校驗內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue 實現(xiàn)axios攔截、頁面跳轉和token 驗證

    vue 實現(xiàn)axios攔截、頁面跳轉和token 驗證

    這篇文章主要介紹了vue 實現(xiàn)axios攔截、頁面跳轉和token 驗證,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07
  • 去除element-ui下拉框的下拉箭頭的實現(xiàn)

    去除element-ui下拉框的下拉箭頭的實現(xiàn)

    我們最開始拿到的element-ui是帶有下拉箭頭的,那么如何去除element-ui下拉框的下拉箭頭的實現(xiàn),本文就詳細的介紹一下,感興趣的可以了解一下
    2023-08-08
  • 關于vue路由緩存清除在main.js中的設置

    關于vue路由緩存清除在main.js中的設置

    今天小編就為大家分享一篇關于vue路由緩存清除在main.js中的設置,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 利用vue實現(xiàn)模態(tài)框組件

    利用vue實現(xiàn)模態(tài)框組件

    這篇文章主要為大家詳細介紹了vue實現(xiàn)模態(tài)框組件的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • vue-quill-editor如何設置字體大小

    vue-quill-editor如何設置字體大小

    這篇文章主要介紹了vue-quill-editor如何設置字體大小,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue中傳遞自定義參數(shù)到后端、后端獲取數(shù)據(jù)并使用Map接收參數(shù)

    Vue中傳遞自定義參數(shù)到后端、后端獲取數(shù)據(jù)并使用Map接收參數(shù)

    有些傳遞的參數(shù)是直接拼接到URL地址欄中的、但是為了統(tǒng)一管理、不能將傳遞的參數(shù)直接拼接到地址欄中,接下來通過本文給大家介紹Vue中傳遞自定義參數(shù)到后端、后端獲取數(shù)據(jù)并使用Map接收參數(shù),感興趣的朋友一起看看吧
    2022-10-10
  • vue.js實現(xiàn)表格合并示例代碼

    vue.js實現(xiàn)表格合并示例代碼

    最近工作中遇到一個需求,是要做一個頁面放張大表格用來顯示數(shù)據(jù)項,純粹為了view層操作方便,就用了vue做渲染。然而又被提出了一個需求,需要相鄰的相同值的行數(shù)據(jù)項進行單元格合并,這就醉了。沒辦法,只能想辦法解決,下面通過這篇文章來一起看看吧。
    2016-11-11
  • 基于Vue3實現(xiàn)印章徽章組件的示例代碼

    基于Vue3實現(xiàn)印章徽章組件的示例代碼

    這篇文章主要介紹了如何利用vue3實現(xiàn)簡單的印章徽章控件,文中通過示例代碼講解詳細,需要的朋友們下面就跟隨小編來一起學習學習吧
    2023-04-04
  • 詳解vue.js實現(xiàn)全屏顯示功能示例

    詳解vue.js實現(xiàn)全屏顯示功能示例

    這篇文章主要為大家介紹了vue.js實現(xiàn)全屏顯示功能示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • 實例解析Vue.js下載方式及基本概念

    實例解析Vue.js下載方式及基本概念

    vue是一套用于構建用戶界面的漸進式框架。接下來通過本文給大家分享Vue.js下載方式及基本概念,感興趣的朋友跟隨腳本之家小編一起學習吧
    2018-05-05

最新評論