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

基于Vue.js的文件選擇與多選對(duì)話框組件Dccfile的使用教程

 更新時(shí)間:2025年04月04日 09:59:00   作者:三線碼工  
在現(xiàn)代前端開(kāi)發(fā)中,Vue.js 提供了強(qiáng)大的組件化開(kāi)發(fā)能力,使得我們可以輕松構(gòu)建復(fù)雜且可復(fù)用的用戶界面,本文將介紹一個(gè)基于 Vue.js 的文件選擇與多選對(duì)話框組件——Dccfile,并詳細(xì)解析其功能和實(shí)現(xiàn)細(xì)節(jié)

在現(xiàn)代前端開(kāi)發(fā)中,Vue.js 提供了強(qiáng)大的組件化開(kāi)發(fā)能力,使得我們可以輕松構(gòu)建復(fù)雜且可復(fù)用的用戶界面。本文將介紹一個(gè)基于 Vue.js 的文件選擇與多選對(duì)話框組件——Dccfile,并詳細(xì)解析其功能和實(shí)現(xiàn)細(xì)節(jié)。

1. 組件概述

Dccfile 是一個(gè)用于文件選擇和多選操作的對(duì)話框組件。它提供了以下功能:

  • 搜索功能:通過(guò)文件編號(hào)或文件名稱(chēng)進(jìn)行篩選。
  • 分頁(yè)展示:支持分頁(yè)查看文件列表。
  • 多選操作:用戶可以選擇多個(gè)文件,并將其添加到“已添加”區(qū)域。
  • 全屏模式:支持切換全屏模式以獲得更大的操作空間。
  • 國(guó)際化支持:通過(guò) $t 方法實(shí)現(xiàn)多語(yǔ)言支持。

以下是組件的主要結(jié)構(gòu):

<template>
  <el-dialog :visible.sync="isShow" width="800px" @close="handlerClose">
    <!-- 對(duì)話框標(biāo)題 -->
    <div slot="title" class="dialog-title">
      <span>{{ title }}</span>
      <i class="s-icon" @click="fullscreen = !fullscreen"></i>
    </div>

    <!-- 主體內(nèi)容 -->
    <el-container>
      <el-main>
        <!-- 搜索表單 -->
        <el-form :model="queryParams" ref="queryForm" :inline="true">
          <el-form-item :label="$t('task.fileNo')" prop="fileNo">
            <el-input v-model="queryParams.fileNo" @keyup.enter.native="handleQuery" />
          </el-form-item>
          <el-form-item :label="$t('task.fileName')" prop="fileName">
            <el-input v-model="queryParams.fileName" @keyup.enter.native="handleQuery" />
          </el-form-item>
          <el-form-item>
            <el-button type="primary" @click="handleQuery">{{ $t("public.search") }}</el-button>
            <el-button @click="resetQuery">{{ $t("public.reset") }}</el-button>
          </el-form-item>
        </el-form>

        <!-- 已添加文件區(qū)域 -->
        <div class="data-wrap">
          <h5>已添加:</h5>
          <div class="data-content">
            <el-tag
              v-for="(item, index) in data"
              :key="index"
              closable
              @close="removeTag(item, index)"
            >
              {{ item.filename }}
            </el-tag>
            <span v-if="data.length == 0" class="holder-select">請(qǐng)選擇</span>
          </div>
        </div>

        <!-- 文件表格 -->
        <el-table :data="tableData" @selection-change="selectionChange">
          <el-table-column type="selection" width="55" align="center" />
          <el-table-column :label="$t('public.serialNum')" type="index" align="center" />
          <el-table-column prop="filenumber" label="文件編號(hào)" align="center" />
          <el-table-column prop="filename" label="文件名稱(chēng)" align="center" />
          <el-table-column prop="uploadname" label="上傳人" align="center" />
          <el-table-column prop="uploadtime" label="上傳時(shí)間" />
        </el-table>

        <!-- 分頁(yè) -->
        <el-pagination
          @size-change="handleSizeChange"
          @current-change="handleCurrentChange"
          :page-sizes="[10, 20, 50, 100]"
          layout="prev, pager, next, sizes"
          :total="total"
        />
      </el-main>

      <!-- 底部按鈕 -->
      <el-footer>
        <el-button @click="cancel">{{ $t("public.close") }}</el-button>
        <el-button type="primary" @click="submitForm">{{ $t("btn.submit") }}</el-button>
      </el-footer>
    </el-container>
  </el-dialog>
</template>

2. 功能詳解

2.1 搜索功能

用戶可以通過(guò)輸入文件編號(hào)或文件名稱(chēng)進(jìn)行搜索。搜索結(jié)果會(huì)實(shí)時(shí)更新表格中的數(shù)據(jù)。

methods: {
  handleQuery() {
    this.queryParams.pageNum = 1;
    this.getList();
  },
  resetQuery() {
    this.resetForm("queryForm");
    this.handleQuery();
  }
}

2.2 多選操作

用戶可以在表格中選擇多個(gè)文件,并將其添加到“已添加”區(qū)域。已選擇的文件會(huì)以標(biāo)簽的形式展示,并支持刪除操作。

methods: {
  selectionChange(selection) {
    this.data = selection;
  },
  removeTag(row, index) {
    this.data.splice(index, 1);
    this.$refs.table.toggleRowSelection(row, false);
  }
}

2.3 分頁(yè)功能

表格支持分頁(yè)展示,用戶可以通過(guò)調(diào)整每頁(yè)顯示的數(shù)量或跳轉(zhuǎn)到指定頁(yè)碼來(lái)查看更多數(shù)據(jù)。

methods: {
  handleSizeChange(size) {
    this.queryParams.pageSize = size;
    this.getList();
  },
  handleCurrentChange(page) {
    this.queryParams.pageNum = page;
    this.getList();
  }
}

2.4 全屏模式

用戶可以通過(guò)點(diǎn)擊標(biāo)題欄中的圖標(biāo)切換全屏模式,以獲得更大的操作空間。

data() {
  return {
    fullscreen: false
  };
},
methods: {
  handlerClose() {
    this.$emit('update:visible', false);
    this.resetDialog();
  }
}

3. 使用方法

要使用該組件,只需在父組件中引入并綁定相關(guān)屬性即可:

<template>
  <Dccfile v-model="visible" :title="title" />
</template>

<script>
import Dccfile from '@/Dccfile/index.vue';

export default {
  components: { Dccfile },
  data() {
    return {
      visible: false,
      title: '選擇文件'
    };
  }
};
</script>

4. 總結(jié)

Dccfile 是一個(gè)功能強(qiáng)大且易于使用的文件選擇與多選對(duì)話框組件。它不僅提供了豐富的交互功能,還支持國(guó)際化和全屏模式,非常適合需要處理文件選擇的場(chǎng)景。希望本文能幫助您更好地理解和使用該組件!

到此這篇關(guān)于基于Vue.js的文件選擇與多選對(duì)話框組件Dccfile的使用教程的文章就介紹到這了,更多相關(guān)Vue文件選擇與多選對(duì)話框組件Dccfile內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Element實(shí)現(xiàn)動(dòng)態(tài)表格的示例代碼

    Element實(shí)現(xiàn)動(dòng)態(tài)表格的示例代碼

    最近有有個(gè)項(xiàng)目,通過(guò)選擇不同的查詢指標(biāo)展示不同的表格,所以本文就介紹一下Element實(shí)現(xiàn)動(dòng)態(tài)表格,具體實(shí)現(xiàn)代碼記錄如下,感興趣的可以了解一下
    2021-08-08
  • vue中的插槽詳解

    vue中的插槽詳解

    這篇文章主要介紹了Vue中的插槽,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-10-10
  • Vue3實(shí)現(xiàn)批量異步更新

    Vue3實(shí)現(xiàn)批量異步更新

    這篇文章主要為大家詳細(xì)介紹了Vue3批量異步更新是如何實(shí)現(xiàn)的,文中的示例代碼簡(jiǎn)潔易懂,具有一定的借鑒價(jià)值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-08-08
  • 如何解決ElementPlus的el-table底白線問(wèn)題

    如何解決ElementPlus的el-table底白線問(wèn)題

    這篇文章主要介紹了如何解決ElementPlus的el-table底白線問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • vue-router beforeEach跳轉(zhuǎn)路由驗(yàn)證用戶登錄狀態(tài)

    vue-router beforeEach跳轉(zhuǎn)路由驗(yàn)證用戶登錄狀態(tài)

    這篇文章主要介紹了vue-router beforeEach跳轉(zhuǎn)路由驗(yàn)證用戶登錄狀態(tài),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • vue3父子組件通信、兄弟組件實(shí)時(shí)通信方式

    vue3父子組件通信、兄弟組件實(shí)時(shí)通信方式

    這篇文章主要介紹了vue3父子組件通信、兄弟組件實(shí)時(shí)通信方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • el-form的label和表單自適應(yīng)填滿一行且靠左對(duì)齊方式

    el-form的label和表單自適應(yīng)填滿一行且靠左對(duì)齊方式

    這篇文章主要介紹了el-form的label和表單自適應(yīng)填滿一行且靠左對(duì)齊方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 關(guān)于vue項(xiàng)目一直出現(xiàn) sockjs-node/info?t=XX的解決辦法

    關(guān)于vue項(xiàng)目一直出現(xiàn) sockjs-node/info?t=XX的解決辦法

    sockjs-node 是一個(gè)JavaScript庫(kù),提供跨瀏覽器JavaScript的API,創(chuàng)建了一個(gè)低延遲、全雙工的瀏覽器和web服務(wù)器之間通信通道,這篇文章主要介紹了vue項(xiàng)目一直出現(xiàn) sockjs-node/info?t=XX的解決辦法,需要的朋友可以參考下
    2023-12-12
  • Vue 自適應(yīng)高度表格的實(shí)現(xiàn)方法

    Vue 自適應(yīng)高度表格的實(shí)現(xiàn)方法

    這篇文章主要介紹了Vue 自適應(yīng)高度表格的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • Vue3實(shí)現(xiàn)canvas畫(huà)布組件自定義畫(huà)板實(shí)例代碼

    Vue3實(shí)現(xiàn)canvas畫(huà)布組件自定義畫(huà)板實(shí)例代碼

    Vue?Canvas是一個(gè)基于Vue.js的輕量級(jí)畫(huà)板組件,旨在提供一個(gè)簡(jiǎn)易的畫(huà)布功能,用戶可以在網(wǎng)頁(yè)上進(jìn)行自由繪圖,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-09-09

最新評(píng)論