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

Element+Vue實現(xiàn)動態(tài)表單多個下拉框組件功能

 更新時間:2023年07月25日 09:51:55   作者:LL金盆  
這篇文章主要介紹了Element+Vue實現(xiàn)動態(tài)表單多個下拉框組件功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

需求

表單的內容為巡檢計劃,巡檢計劃可以選擇多個巡檢點位,每個巡檢點位可以選擇多個設備和對應操作。

最終效果圖

  • 點擊加號圖標增加一個下拉框
  • 減號圖標刪除對應下拉框
  • 下拉框備選項目相同
  • 點擊設置動作按鈕,彈出可編輯表格,可以為該巡檢點位設置多個動作

選擇多個點位

  • 表格每行內容可編
  • 設別名稱下拉框和設備動作下拉框聯(lián)動
  • 操作按鈕可對選項進行上下排序

每個點位選擇單獨的動作

代碼實現(xiàn)

1.定義表單結構

<el-dialog :title="dialogTitle" :visible.sync="addDialogOpen" width="650px">
   <div class="dialogForm">
     <el-form :rules="rules" :model="addForm" ref="addForm" label-width="80px">	
		精簡了無關代碼
       <el-form-item label="巡檢內容" prop="patrolContent">
         <div class="patrol-content">
           <div class="point">
           patrolContent元素個數控制下拉框的個數
           循環(huán)渲染
           每個div中包含一個下拉框、三個按鈕
             <div class="point-item"
                  v-for="(item,index) in addForm.patrolContent"
                  :key="index">
               <div class="point-select">
                 <el-select v-model="item.point" class="selectItem" placeholder="請選擇巡檢點位(先選擇地圖)">
                   <el-option v-for="(item,index) in pointOptions"
                              :key="index"
                              :label="item.point_name"
                              :value="item.point_name">
                   </el-option>
                 </el-select>
                 <el-button size="mini" icon="el-icon-circle-plus" type="primary"
                            @click="addPointSelectItem(index)"/>
                 <el-button size="mini" icon="el-icon-remove" type="info"
                            @click="removePointSelectItem(index)"/>
                 <el-button size="mini" type="success"
                            @click="addDeviceAction(index)">設置動作
                 </el-button>
               </div>
             </div>
           </div>
         </div>
       </el-form-item>
     </el-form>
   </div>
</el-dialog>

2.在data()中定義需要綁定的模板變量

addForm: {
  patrolContent: [ //有多少個元素就渲染多少個下拉框
    {
      point: '', //點位
      children: [], //對應每個點位的具體動作
    }
  ]
}

3.定義增減下拉框的方法,實現(xiàn)動態(tài)增減

// 增加一個巡檢點下拉框
addPointSelectItem(index) {
  this.addForm.patrolContent.splice(index + 1, 0,
      {
        point: '',
        children: [] //為空表示該點還未設置動作
      }
  )
},
// 刪除一個巡檢點下拉框
removePointSelectItem(index) {
  if (this.addForm.patrolContent.length > 1) {
    this.addForm.patrolContent.splice(index, 1)
  }
},

至此,已經實現(xiàn)了下拉框的動態(tài)增減,且下拉框的選項之間互不影響。接下來繼續(xù)實現(xiàn)每個點位可以配置不同的動作。

4.定義打開動作彈窗的函數

這里在打開彈窗時,首先獲取到所點擊的下拉框索引值index,index代表了該元素在patrolContent中的位置,通過index獲取表格要綁定的變量(該元素中的children)。

// 在該點位添加動作:打開彈窗
addDeviceAction(index) {
  this.dialogTableData = this.addForm.patrolContent[index].children
  this.deviceDialogOpen = true
}

5.定義動作彈窗

在彈窗打開時,表格會根據children中的元素進行渲染。

表格借助v-if實現(xiàn)了編輯和確認編輯邏輯。

實現(xiàn)表格項的增刪較為簡單,增刪children列表中的元素即可。

<el-dialog title="選擇動作" :visible.sync="deviceDialogOpen" width="800px">
  <div class="device-dialog">
    <el-table :data="dialogTableData" border>
      <el-table-column align="center" label="序號" type="index" width="50"/>
      <el-table-column align="center" label="設備名稱" prop="device">
        <template v-slot="scope">
          <el-select v-show="scope.row.edit" v-model="scope.row.device"
                     class="selectItem"
                     placeholder="選擇設備"
                     @change="deviceSelectChange">
            <el-option value="機械臂" label="機械臂"/>
            <el-option value="升降臺" label="升降臺"/>
            <el-option value="攝像頭" label="攝像頭"/>
          </el-select>
          <span v-show="!scope.row.edit">
            {{ scope.row.device }}
          </span>
        </template>
      </el-table-column>
      <el-table-column align="center" label="設備動作" prop="action">
        <template v-slot="scope">
          <el-select v-show="scope.row.edit"
                     value-key="id"
                     v-model="scope.row.action"
                     class="selectItem"
                     placeholder="選擇動作">
            <el-option v-for="item in actionOptions"
                       :key="item.label"
                       :value="item.value"
                       :label="item.label">
            </el-option>
          </el-select>
          <span v-show="!scope.row.edit">
            {{ scope.row.action['action_name'] }}
          </span>
        </template>
      </el-table-column>
      <el-table-column align="center" label="操作" width="300">
        <template v-slot="scope">
          <el-button size="mini" type="primary" v-show="!scope.row.edit" @click="editAction(scope.row)">編輯
          </el-button>
          <el-button size="mini" type="success" v-show="scope.row.edit" @click="scope.row.edit=!scope.row.edit">
            確定
          </el-button>
          <el-button size="mini" type="danger" @click="delAction(scope.$index)">刪除</el-button>
          <el-button size="mini" type="primary" plain @click="upMoveItem(scope.$index)"
                     icon="el-icon-caret-top"></el-button>
          <el-button size="mini" type="warning" plain @click="downMoveItem(scope.$index)"
                     icon="el-icon-caret-bottom"></el-button>
        </template>
      </el-table-column>
    </el-table>
    <div class="footer">
      <el-button type="warning" @click="addAction">添加</el-button>
      <el-button type="primary" @click="deviceDialogOpen=false">確定</el-button>
    </div>
  </div>
</el-dialog>

6.實現(xiàn)表格項增減方法以及排序方法

// 彈窗-表格中增加一條數據
addAction() {
  this.dialogTableData.push({
    device: '', //綁定設備選項
    action: '', //綁定設備動作選項
    edit: true, // 默認可編輯
  })
},
// 彈窗-刪除表格中的一條數據
delAction(index) {
  this.dialogTableData.splice(index, 1)
},
// 上移元素
upMoveItem(index) {
  let table = this.dialogTableData
  if (index !== 0) {
    table[index] = table.splice(index - 1, 1, table[index])[0]
  } else {
    table.push(table.shift())
  }
},
// 下移元素
downMoveItem(index) {
  let table = this.dialogTableData
  if (index !== table.length - 1) {
    table[index] = table.splice(index + 1, 1, table[index])[0];
  } else {
    table.unshift(table.splice(index, 1)[0]);
  }
},

總結

  • 需要明確嵌套層級,vue組件要綁定到正確的變量上
  • 為某個選項增加具體動作時,要獲取到索引,這樣才能根據索引獲取該選項下的數據
  • 選項的增刪和排序都利用了splice()函數

到此這篇關于Element+Vue實現(xiàn)動態(tài)表單(多個下拉框組件)的文章就介紹到這了,更多相關Element Vue動態(tài)表單內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue項目引入Iconfont圖標庫的教程圖解

    vue項目引入Iconfont圖標庫的教程圖解

    這篇文章主要介紹了vue項目引入Iconfont圖標庫的相關知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-10-10
  • Vue3實現(xiàn)掛載全局方法和用getCurrentInstance代替this

    Vue3實現(xiàn)掛載全局方法和用getCurrentInstance代替this

    這篇文章主要介紹了Vue3實現(xiàn)掛載全局方法和用getCurrentInstance代替this,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-04-04
  • 關于Vue.js 2.0的Vuex 2.0 你需要更新的知識庫

    關于Vue.js 2.0的Vuex 2.0 你需要更新的知識庫

    關于Vue.js 2.0 的 Vuex 2.0你需要更新的知識庫,感興趣的小伙伴們可以參考一下
    2016-11-11
  • vue腳手架搭建過程圖解

    vue腳手架搭建過程圖解

    vue腳手架是個好東西,能夠快速搭建vue單頁面應用,vue是基于node環(huán)境的,所以要先安裝node。下面通過圖文并茂的形式給大家介紹vue腳手架搭建過程圖解,感興趣的朋友一起看看吧
    2018-06-06
  • 不能通過IP地址訪問VUE項目的問題及解決

    不能通過IP地址訪問VUE項目的問題及解決

    這篇文章主要介紹了不能通過IP地址訪問VUE項目的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Vue結合ElementUI實現(xiàn)數據請求和頁面跳轉功能(最新推薦)

    Vue結合ElementUI實現(xiàn)數據請求和頁面跳轉功能(最新推薦)

    我們在Proflie.vue實例中,有beforeRouteEnter、beforeRouteLeave兩個函數分別是進入路由之前和離開路由之后,我們可以在這兩個函數之內進行數據的請求,下面給大家分享Vue結合ElementUI實現(xiàn)數據請求和頁面跳轉功能,感興趣的朋友一起看看吧
    2024-05-05
  • vue前端測試開發(fā)watch監(jiān)聽data的數據變化

    vue前端測試開發(fā)watch監(jiān)聽data的數據變化

    這篇文章主要為大家介紹了vue測試開發(fā)watch監(jiān)聽data的數據變化,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • Vue 表單輸入綁定v-model

    Vue 表單輸入綁定v-model

    這篇文章主要介紹了Vue 表單輸入綁定v-model,v-model指定可以實現(xiàn)表單值與屬性的雙向綁定。即表單元素中更改了值會自動的更新屬性中的值,屬性中的值更新了會自動更新表單中的值 ,下面一起進入文章來哦姐文章詳情內容
    2021-10-10
  • vue實現(xiàn)移動端H5數字鍵盤組件使用詳解

    vue實現(xiàn)移動端H5數字鍵盤組件使用詳解

    這篇文章主要為大家詳細介紹了vue實現(xiàn)移動端H5數字鍵盤組件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • vue使用formData時候傳遞參數是個空值的情況處理

    vue使用formData時候傳遞參數是個空值的情況處理

    這篇文章主要介紹了vue使用formData時候傳遞參數是個空值的情況處理,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05

最新評論