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

vue+element自定義查詢組件

 更新時間:2021年09月29日 08:54:02   作者:吳維煒  
這篇文章主要為大家詳細介紹了vue+element自定義查詢組件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文主要介紹vue項目,在引入element的前提下,對組件進行二次封裝實現(xiàn)通過配置項直接布局。

一、查詢條件組件化

結合EventBus.js的使用,傳遞事件更高效,可以避免各種復雜的生命周期依賴關系。
components/dataForm文件夾下dataForm.vue作為組件集合的載體,并創(chuàng)建配置項

1.1 dataForm代碼實例

// dataForm.vue
<template>
  <el-row>
    <input-form v-for="(item,index) in options" :key="'dataForm_'+index"> 
      <!-- 輸入框-->
      <input-form
        :key="index"
        v-if="item.type == 'input'"
        :data='item'
      ></input-form>
  </el-row>
</template>
<script>
import EventBus from "@/assets/js/eventBus.js"
import InputForm "@/components/dataForm/InputForm"
export default {
  components: {
    InputForm,
  },
  props: {
    /**
     * 表單配置項
     * @param {Object} option 配置參數(shù),具體如下:
     * type: 表單項類型,String, 可選值input
     */
    options: {
      type: Array,
      default() {
        return [];
      },
    },
  },
  data() {
   return {}
  },
  created() {
   // 此處主要是為了實現(xiàn)下拉框對其他子組件的顯示和隱藏
    EventBus.$on("refreshDataForm", e => {
      this.refreshDataForm(e);
    });
  },
  // 頁面銷毀 事件銷毀
  beforeDestroy() {
    EventBus.$off("refreshDataForm")
    EventBus.$off("handleClick")
  },
  methods: {
   // 更新表單數(shù)據(jù)
    refreshDataForm(item) {
      let data = this.options
      data.forEach((e, i) => {
        if (item.type == e.type && item.name == e.name) {
          this.options[i] = item
        }
      })
    },
    // 子組件點擊事件響應父組件,數(shù)據(jù)傳遞
    handleClick(data) {
     EventBus.$emit("handleClick",data)
    },
    // 表單數(shù)據(jù)格式化 (可以對是否必填項目做必填校驗)
    getDataForm() {
     let data = this.options
     let formObj = {}
     let error = ''
     try {
      data.forEach(e => {
       if (e.type === ''input) {
        if (e.require && !e.content) {
         error = '請輸入' + e.label
         throw error
        }
        formObj[e.name] = e.content
       } else if (e.type === 'select' || e.type === 'dataSelect') {
        if (e.require && !e.content) {
         error = '請選擇' + e.label
         throw error
        }
        formObj[e.name] = e.content
       } else if (e.type === 'date' || e.type === 'dataRadio') {
        if (e.require && !e.content) {
         error = '請選擇' + e.label
         throw error
        }
        formObj[e.beginName] = e.beginRegTime
        formObj[e.endName] = e.endRegTime
       } else if (e.type === 'image') {
        formObj[e.name] = e.file || e.content
       } else if (e.type === 'upload') {
        formObj[e.name] = e.file || e.content
        if (e.delFileName) { // 刪除附件集合及自定義名稱和默認名稱
          formObj[e.delFileName] = e.delFileIds.join(',')
        } else {
         formObj['delFileName'] = e.delFileIds.join(',')
        }
       }
      })
      return formObj
     } catch (error) {
      this.$message({ message:error, type: 'error'})
     }
    }
  }
}

1.2 子組inputForm.vue

注:此處被引用的組件也可以被頁面單獨引用

<template>
  <el-col>
    <el-col :span="data.boxSpan?data.boxSpan:boxSpan" v-if="!data.isHide">
     <el-col :span="data.infoSpan?data.infoSpan:infoSpan" >
      <el-col :span="data.infoSpan?data.infoSpan:infoSpan" v-if="data.labelSpan!=0">
       <label class="el-form-item_label" :class="{'require': data.require}" v-html="data.label"></label>
      </el-col>
      <el-col :span="data.contentSpan?data.contentSpan:contentSpan" v-if="data.contentSpan!=0">
       <el-input :class="{'base_textarea': data.textarea}" v-modle.trim="data.content" :type="data.textarea?'textarea':''" :disable="data.readOnly" :placeholder="setPlaceholder" maxlength="200"></el-input>
      </el-col>
     </el-col>
      <span v-text="title"></span>
    </div>
  </el-col>
</template>
<script>
export default {
 props: {
  // 類型 input 輸入框
  type: {
   type: String,
   default: 'input'
  },
  // 默認柵欄布局 8/24
  boxSpan: {
   type: Number,
   default: 8
  },
  // 默認柵欄布局 24/24
  infoSpan: {
   type: Number,
   default: 24
  },
  // 默認柵欄布局 8/24
  spanSpan: {
   type: Number,
   default: 8
  },
  // 默認柵欄布局 16/24
  contentSpan: {
   type: Number,
   default: 16
  },
  /**
  * name 關鍵字
  * type 表單類型
  * label 表單標題
  * content 表單內(nèi)容
  * readOnly 是否只讀 默認否
  * isHide 是否隱藏 默認否
  * textarea 是否文本類型 默認否
  **/
  data: {
   type: Object,
   default() {
    return []
   }
  }
 },
 computed: {
  setPlaceholder() {
   if(this.data.readOnly && !this.data.content) {
    return ''
   } 
   return '請輸入'
  }
 }
}
</script>
<style scoped>
 // 必填樣式
 .require::after {
  content: '*';
  color:red;
 }
 // flex布局標題垂直居中
 .el-form-item__label {
  float:right;
  margin-botton:0;
  line-height: 20px;
  display: flex;
  align-items: center;
  min-height: 40px;
 }
</style>

1.3 父頁面引用及使用

<template>
  <el-row>
    <data-form :options='searchArray' ref='searchArray'></input-form>
  </el-row>
</template>

<script>
 import EventBus from "@/assets/js/eventBus.js"
 import DataForm "@/components/dataForm/dataForm"
 export default {
  components: {
   DataForm
  },
  data() {
   return {
    // 查詢菜單配置
    searchArray: [
     {
      name: 'personName',
      type: 'input',
      label: '用戶名',
      content: ''
     },
     {
      name: 'personName2',
      type: 'input',
      label: '用戶名2',
      content: ''
     }
    ]
   }
  },
  created() {
   // 監(jiān)聽子組件傳參
   EventBus.$on('refreshDataForm', e => {
    this.refreshDataForm(e)
   })
  },
  destroyed() {
   // 銷毀子組件傳參監(jiān)聽
   EventBus.$off('refreshDataForm')
  },
  methods: {
   // 監(jiān)聽子組件操作
   refreshDataForm(e) {
    // 邏輯代碼
    this.$forceUpdate()
   },
   // 數(shù)據(jù)查詢
   handleQuery() {
     // 獲取組件參數(shù)返回json格式
    let searchArray = this.$refs.searchArray.getDataForm()
    // 如果存在必填項,返回值為null,此時有彈窗提示
    if (!searchArray) {
     return 
    }
    // 查詢接口邏輯
   }
  }
 }
</script>

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 如何在基于vue-cli的項目自定義打包環(huán)境

    如何在基于vue-cli的項目自定義打包環(huán)境

    本篇文章主要介紹了在基于vue-cli的項目自定義打包環(huán)境,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • Vue新一代狀態(tài)管理工具Pinia的具體使用

    Vue新一代狀態(tài)管理工具Pinia的具體使用

    本文主要介紹了Vue新一代狀態(tài)管理工具Pinia的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • Vue2實現(xiàn)圖片的拖拽,縮放和旋轉效果的示例代碼

    Vue2實現(xiàn)圖片的拖拽,縮放和旋轉效果的示例代碼

    這篇文章主要為大家介紹了如何基于vue2?實現(xiàn)圖片的拖拽、旋轉、鼠標滾動放大縮小等功能。文中的示例代碼講解詳細,感興趣的小伙伴可以嘗試一下
    2022-11-11
  • vue權限問題的完美解決方案

    vue權限問題的完美解決方案

    今天來說說權限管理,因為網(wǎng)上已經(jīng)有很多關于這方面的很多內(nèi)容,下面這篇文章主要給大家介紹了關于vue權限問題的完美解決方案,需要的朋友們下面來一起學習學習吧
    2019-05-05
  • Vue中使用vue2-perfect-scrollbar制作滾動條

    Vue中使用vue2-perfect-scrollbar制作滾動條

    這篇文章主要介紹了Vue中使用vue2-perfect-scrollbar滾動條,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • vue中如何給多個按鈕動態(tài)添加類名

    vue中如何給多個按鈕動態(tài)添加類名

    這篇文章主要介紹了vue中如何給多個按鈕動態(tài)添加類名問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Vue3在router中使用pinia報錯的簡單解決辦法

    Vue3在router中使用pinia報錯的簡單解決辦法

    這篇文章主要給大家介紹了關于Vue3在router中使用pinia報錯的簡單解決辦法,什么是pinia,可以理解為狀態(tài)管理工具,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-08-08
  • vue3利用customRef實現(xiàn)防抖

    vue3利用customRef實現(xiàn)防抖

    防抖就是對于頻繁觸發(fā)的事件添加一個延時同時設定一個最小觸發(fā)間隔,防抖大家都學過,但是如何在?Vue3?里中將防抖做到極致呢,下面小編就來和大家詳細講講
    2023-10-10
  • vue v-on監(jiān)聽事件詳解

    vue v-on監(jiān)聽事件詳解

    這篇文章主要為大家詳細介紹了vue v-on監(jiān)聽事件的相關資料,Vue.js中的監(jiān)聽事件是如何處理的,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • Vue.js中數(shù)組變動的檢測詳解

    Vue.js中數(shù)組變動的檢測詳解

    這篇文章給大家主要介紹了Vue.js中數(shù)組變動的檢測,文中給出了詳細的示例代碼和過程介紹,相信會對大家的理解和學習很有幫助,有需要的朋友們下面來一起看看吧。
    2016-10-10

最新評論