Vue + TypeScript + ElementUI 封裝表頭查詢組件

来源:https://www.cnblogs.com/wisewrong/archive/2018/05/21/9052467.html
-Advertisement-
Play Games

前段時間有朋友私信我 Vue + TypeScript 的問題,然後就打算寫一篇 Vue + TypeScript 封裝組件的文章 正好公司項目中需要封裝一個表頭查詢組件,就拿出來分享一下~ 組件的整體思路是通過一個 config 數組生成列表的頭部表單: PS:配合《Vue 爬坑之路(九)—— 用 ...


前段時間有朋友私信我 Vue + TypeScript 的問題,然後就打算寫一篇 Vue + TypeScript 封裝組件的文章

正好公司項目中需要封裝一個表頭查詢組件,就拿出來分享一下~

 

組件的整體思路是通過一個 config 數組生成列表的頭部表單:

PS:配合《Vue 爬坑之路(九)—— 用正確的姿勢封裝組件》食用更佳

 

一、組件設計

這個組件由兩部分組成:輸入組件和按鈕

其中輸入組件可以通過 v-for 迴圈渲染,並通過 v-if 來切換輸入框 input 和下拉框 select

每個輸入組件都有各自的 v-model,可以在 config 傳入對應的 code 來綁定對應的參數

基於這些想法,組件的基本結構就出來了:

 

由此可以設計出 config 的數據結構 data.ts:

/*
 * data.ts
 *
 * 數據類型 - table-header 組件
 */

export class SelectOptionItem {
  public value: String | Number;
  public label: String | Number;
}

export class HeaderConfigItem {
  public title: String;
  public code: String;
  public type?: 'select' | 'input';
  public options?: SelectOptionItem[]
}

 

 

二、內部邏輯

整個組件需要傳入兩個必選參數:config 和 data

data 是整個表頭的數據對象,config 就是整個組件的配置項,由此渲染出頭部結構

 

 然後還有“查詢”和“清空”兩個按鈕

這類公共組件不建議直接處理事件,所以通過 emit 將事件拋給父組件處理

這裡的 this._copy 是 data 的拷貝對象,在 mounted 的時候將 data 拷貝出來作為初始值,清空的時候再將這個初始值傳回去

這裡會涉及到在子組件中對父組件傳入的參數直接修改,所以需要用 sync 修飾符

 

三、完整代碼

除了這些基本邏輯之外,我還添加了一個 size 用於控制整體的尺寸,然後基於自身的項目微調了樣式,所以這部分僅做參考

<template>
  <div class="table-header">
    <el-form :inline="true" :model="data" class="form--label-left" label-width="180px">
      <el-row :gutter="20">
        <el-col :span="8" v-for="item in config" :key="item.code">
          <el-form-item :label="item.title" class="table-header-item">
            <el-select v-if="item.type === 'select'" v-model="data[item.code]" :placeholder="`請輸入${item.title}`" :size="size" clearable>
              <el-option v-for="option in item.options" :key="option.value" :value="option.value" :label="option.label"></el-option>
            </el-select>
            <el-input v-else v-model="data[item.code]" :placeholder="`請輸入${item.title}`" :size="size"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="8" class="table-header_button">
          <el-button :size="size" type="text" @click="reset">清空</el-button>
          <el-button :size="size" type="primary" icon="el-icon-search" @click="search">查詢</el-button>
        </el-col>
      </el-row>
    </el-form>
  </div>
</template>

<script lang="ts">
  import { Component, Prop, Vue } from 'vue-property-decorator';
  import { HeaderConfigItem } from "./data.ts";

  @Component({})
  export default class TableHeader extends Vue {
    public _copy: Object = {}
    @Prop({ default: function () {
        return 'small'
      }})
    size: 'small' | 'mini' | 'medium'

    @Prop({})
    data: Object

    @Prop({default: []})
    config: HeaderConfigItem[]

    mounted() {
      this._copy = Object.assign({}, this.data)
    }
    // 查詢
    search() {
      this.$emit('search', this.data)
    }
    // 清空
    reset() {
      this.$emit('update:data', Object.assign({}, this._copy))
      this.search()
    }
  }
</script>

<style lang="scss">
.table-header {
  padding-top: 10px;
  .table-header_button {
    text-align: right;
    float: right;
    margin-bottom: 12px;
    line-height: 40px;
  }
  .table-header-item.el-form-item {
    width: 100%;
    display: flex;
    flex: auto;
    margin-bottom: 12px;
    .el-form-item__content, .el-select {
      width: 100%;
    }
  }
}

</style>

父組件調用:

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 項目中使用了EJS,因此,也開始接觸了EJS。 EJS官方定義:it's just plain JavaScript。 總的來說,上手較快(畢竟我是個菜鳥)。 第一步:安裝: 第二部使用: 在html中,嵌套ejs標簽。 使用較多的是:<%,這個的作用是控制流。代碼實例: 其實很簡單,就是正常的ht ...
  • Vue.js 的核心是一個允許採用簡潔的模板語法來聲明式地將數據渲染進 DOM 的系統; 指令帶有首碼 v-,以表示它們是 Vue 提供的特殊特性; v-for 指令可以綁定數組的數據來渲染一個項目列表; 為了讓用戶和你的應用進行交互,我們可以用 v-on 指令添加一個事件監聽器,通過它調用在 Vu ...
  • 內容:Node.js應用組成,第一個應用創建+代碼 ###########################################################################Node.js 應用組成• 引入 required 模塊:我們可以使用 require 指令來載入 ...
  • __proto__、prototype傻傻分不清楚? 記住以下兩點:1.__proto__是每個對象都有的一個屬性,而prototype是函數才會有的屬性。2.__proto__指向的是當前對象的原型對象,而prototype指向的,是以當前函數作為構造函數構造出來的對象的原型對象 (寫在最前面,轉 ...
  • 深入css佈局(2) — 定位與浮動 在css知識體系中,除了css選擇器,樣式屬性等基礎知識外,css佈局相關的知識才是css比較核心和重要的點。今天我們來深入學習一下css佈局相關的知識。 上篇文章我們講完了css佈局中盒模型和元素分類的相關知識,同時介紹了box-sizing和行框。這篇我們繼 ...
  • 一 JS中有哪些數據類型? -- 共 6 種數據類型,其中 5 種基本數據類型Undefined,Null,Boolean,Number和 String,1 種複雜數據類型Object。因為ECMAScript不支持創建任何自定義的類型,所以最終所有的類型都是其中 6 種數據類型之一。(ES6中新增 ...
  • <el-table :data="tableData" stripe border style="width:100%" highlight-current-row> <el-table-column type="selection" width="55"> </el-table-column> < ...
  • 經實驗,$.serializeArray()獲取不到disabled的值,如果想要讓input元素變為不可用,可以把input設為readonly,而不是disabled; 還有一種情況獲取不到值,當頁面中有兩個一樣name值的標簽的時候,即使其中一個name值的input的樣式為 display: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...