使用 Ant Design Vue 你可能會遇到的14個問題

来源:https://www.cnblogs.com/zsxblog/archive/2023/10/22/17780269.html
-Advertisement-
Play Games

公司有一個新需求,在原來項目基礎上開發,項目中使用 Ant Design Vue,版本是 1.X ,在此記錄下遇到的問題;對於沒有使用過或者使用程度不深的同學來說,希望可以幫助你在開發中遇到問題時有個參考。對於已經熟練使用的同學,可能這些問題都遇到過,歡迎大家在評論區補充。 1、實現對下拉框顯示的所 ...


公司有一個新需求,在原來項目基礎上開發,項目中使用 Ant Design Vue,版本是 1.X ,在此記錄下遇到的問題;對於沒有使用過或者使用程度不深的同學來說,希望可以幫助你在開發中遇到問題時有個參考。對於已經熟練使用的同學,可能這些問題都遇到過,歡迎大家在評論區補充。

1、實現對下拉框顯示的所有元素的搜索,包括元素的label, value等等

添加 optionFilterprop = "children",並且下拉框的每條數據不能用標簽包裏,必須是純模板標簽

可以是:

<a-select option-filter-prop="children">
    <a-select-option 
        v-for-"item in countryList" 
        :key="item.biccode" 
        :value="item.biccode"
    > 
        {{item.cname}} | {{item.biccοde}}  <!-- 不能用標簽包裹 -->
    </a-select-option> 
</a-select>

如果需要用標簽包裹,則需要搭配 :filter-option 屬性

<a-select 
    option-filter-prop="children"
    :filter-option="filterOption"
>
    <a-select-option 
        v-for-"item in countryList" 
        :key="item.biccode" 
        :value="item.biccode"
    > 
        <span>{{item.cname}} | {{item.biccοde}}</span>
    </a-select-option> 
</a-select>

filterOption(input, option) {
    // option.componentOptions.children[0].elm.innerText,需要保證這一段取到選中數據的 innerText
    return (option.componentoptions.chi1dren[0].elm.innerText.toLowerCase().indexof(input.toLowerCase())>= 0);
}

2、表單項的 change 函數調用 this.form.getFieldError('欄位名') 拿到的是上次調用的校驗結果,不是實時岀觀的校驗

changeEquiRmbAmt(e,str){
    this.form.validateFields(['field1'], (errors, values) => { 
        console. 1og(errors) //這裡拿到的是上次校驗的結果
    });
}

解決方式一:加 setTimeout,感覺不太好(this.$nextTick()不生效)

changeEquiRmbAmt(e,str){
    setTimeout(() =>{
        this.form.validateFields(['field1'], (errors, values) => { 
            console. 1og(errors) //這裡拿到的是最新校驗的結果
        });
    },10)
}

解決方式二:在自定義校驗器 validator 中添加回調,當欄位校驗發生錯誤後觸發回調。


<a-input 
    v-decorator="[ 'price', {
        rules: [{ validator: checkPrice }], 
    }]" 
/>

// mixins.js
checkPrice(rule, value, callback) {
    if (value.number > 0) { 
        callback(); 
        return; 
    } 
    callback('發生錯誤');
    this.$emit('sendError',rule) //觸發回調
}

// 頁面中監聽 sendError
this.$on('sendError',(rule) =>{
    if(rule.field==='price'){
         執行操作
    }
})

3、v-decorator 模式下無法使用 computed

當一個欄位的顯示隱藏,依賴多個欄位的綜合結果時,通常使用 computed ;但在v-decorator 模式下無法使用類似 v-if="this.form.value1" 的寫法,只能使用 this.form.getFieldValue('value1');並且在項目頁面有很多這種場景的時候,不能使用 computed 就難受了;

所以這裡可以定義一個對象和 this.form 一樣的 this.cloneForm

onValuesChange(props,values){
    if(values){
        for (const key in values){
            if(values.hasOwnProperty(key)){
                if(!this.cloneFonm.hasOwnProperty(key) || this.cloneForm[key]!==values[key]){
                    this.$set(this.cloneForm,key,values[key])
                }
            }    
        }
        // console.log(this.cloneForm)
    }
}

這樣當 form 的表單項任意值改變時,cloneForm 都能及時改變,相應的在 computed 裡面也能使用 this.cloneForm

4、tabs標簽頁切換綁定值 activekey 變了,但沒有切換過來

使用 activeKey 代替 defaultActivekеу

<a-tabs :defaultActivekеу="activeKey">
</a-tabs>

改為

<a-tabs :activeKey="activeKey">
</a-tabs>

5、輸入框中輸入時卡頓

給表單增加 selfUpdate 屬性

<a-form :form="form" :selfUpdate="true"></a-form>

若表單中某個組件輸入依舊卡頓,則可以將該組件提取出來,單獨用另外的 form 包裝;

6、表單校驗時,控制台有顯示 async-validator 返回的錯誤信息,但欄位上沒有標紅,也沒有顯示錯誤提示

在發現模板中綁定沒有什麼問題的話,可以檢查下自定義校驗函數的邏輯,可能有兩種情況

  • 校驗函數中沒有順利走到 callback()
  • 校驗函數順利走到 callback(),但後續執行代碼發生錯誤,沒有拋出錯誤

如果在自定義校驗函數中存在語法錯誤,ant-design-vue 貌似預設不會拋出;此時可以用 try catch 檢查下是否發生了錯誤。

比如下麵的代碼執行後就有問題,沒有在 callback('請輸入') 執行後 return,繼續往下執行,導致所校驗欄位不會標紅

const check = (rule, value, callback) => {
    if ([undefined,'',null].includes(value)) {
        callback('請輸入')
        // return ,如果希望此時校驗結束,則需要添加 return
    }
    callback()
};

而且,還需要註意的是,一個表單中綁定了多個自定義校驗函數的話,其中一個自定義校驗函數有邏輯錯誤,則該表單中其他欄位在執行自定義校驗的時候也不會標紅;

7、Invalid prop: custom validator check failed for prop “fileList“

有個場景是:上傳文件後,查看詳情,將詳情的數據賦值給 fileList

arr.forEach((item) =>{
    item.name = item.fileName
})
this.fileList = arr

此時報錯了,原因是 fileList 未獲取到對應的數據類型的數據,需要將 uid 和 status 加上

arr.forEach((item) =>{
    item.name = item.fileName
    item.uid = item.uid
    item.status = item.status
})
this.fileList = arr

8、cannot set a form field before rendering a field associated with the value

在呈現與值關聯的欄位之前,無法設置表單欄位

  • 第一反應是添加 this.$nextTick() ,但。。無效
  • formItem 上添加 key,無效
  • formItem 上添加 selfUpdate,無效
  • 添加 setTimeout ,有效。。

難道就是渲染慢?

9、表格列設置寬度無效

以下設置無效

:scroll{x:120%}
:scroll{x:'1000'}

以下設置有效

:scroll{x:'1000px'}
:scroll{x:1000}
:scroll{x:'120%'}

10、表單使用v-decorator模式,點擊label 輸入框聚焦問題解決方案

a-form-item 標簽上添加和 v-decorator 綁定的欄位名不一樣的 id

<a-form-item
    label="Note"
    id="noteId" // 添加和 v-decorator 綁定的欄位名不一樣的 id
> 
    <a-input v-decorator="['note', { rules: [{ required: true, message: 'Please' }] }]" /> 
</a-form-item>

11、table表格選中項的清除問題

rowSelection 中需要將 selectedRowKeys 返回

<template>
    <a-table
      ref="table"
      :row-selection="rowSelection"
      :pagination="false"
      bordered
      :rowKey="(record, index) => { return index }">
    </a-table>
</template>
<script>
  data(){
    return{
      selectedRows: [],
      selectedRowKeys: [],
    }
  },
  computed:{
    rowSelection(){
      const { selectedRowKeys } = this;
      return {
        selectedRowKeys, // 需要加上這一行,清除才會有作用
        onChange: (selectedRowKeys, selectedRows) => {
          this.selectedRowKeys = selectedRowKeys
          this.selectedRows = selectedRows
        },
      }
    },
  },
</script>

12、調用表單清空方法後,Select組件的placeholder不顯示的問題

表單清空方法中需設置值為 undefined,不能是空字元串

this.form.setFields({'feePay':{value:undefined,error:null}})

13、a-affix 固釘組件,寬度未隨父容器寬度變化

設置 <a-affix> 寬度 100%

<Affix :style="{ width: '100%' }" :offset-top="10"></Affix>

14、編輯表格數據時,在輸入框輸入一個字元後,輸入框立馬失去焦點了,導致不能正常的連續輸入字元

輸入框所在列的 dateIndex 設置的是 remitMemo,remitMemo 具有唯一性。所以給表格的 rowKey 設置的也是 remitMemo,這裡修改 rowKey 為其他具有唯一性的欄位即可......

// 輸入框的配置數據
{
  title: 'remitMemo',
  dataIndex: 'remitMemo',
  width: '30%',
  scopedSlots: { customRender: 'remitMemo' },
}

// 改為其他具有唯一性的欄位
<a-table rowKey="remitMemo">  =>  <a-table rowKey="uid">

總結

目前做的這個項目體量不算太大,但也遇到了很多問題,上面記錄了和 antDesignVue 相關的14個問題。各位大佬有不同意見或者遇到過其他問題的可以在評論區補充;


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

-Advertisement-
Play Games
更多相關文章
  • 本文介紹在C++語言中,使用一個函數,並返回兩個及以上、同類型或不同類型的返回值的具體方法。 對於C++語言而言,其不能像Python等語言一樣在一個函數中返回多個返回值;但是我們也會經常遇到需要返回兩個甚至更多個值的需求。針對這種情況,我們可以通過pair、tuple(元組)等數據結構,實現C++ ...
  • 1. 什麼是虛擬線程 虛擬線程是JDK21版本正式發佈的一個新特性。虛擬線程和平臺線程主要區別在於,虛擬線程在運行周期內不依賴操作系統線程:它們與硬體脫鉤,因此被稱為“虛擬”。這種解耦是由JVM提供的抽象層賦予的。 虛擬線程的運行成本遠低於平臺線程。它們消耗的記憶體要少得多。這就是為什麼我們可以創建數 ...
  • 大家好,我是大彬~ 今天跟大家分享知識星球小伙伴關於【非科班轉碼如何補基礎】的提問。 往期星球提問整理: 讀博?找工作? 性格測試真的很重要 想找一份實習工作,需要準備什麼 球友提問: 大彬大佬,想問下非科班要補哪些基礎? 求推薦視頻,國內國外都行。 大彬的回答: 你好,我也是非科班轉碼的,Java ...
  • ARP (Address Resolution Protocol,地址解析協議),是一種用於將 `IP` 地址轉換為物理地址(`MAC地址`)的協議。它在 `TCP/IP` 協議棧中處於鏈路層,為了在區域網中能夠正確傳輸數據包而設計,由協議數據單元和對應的操作命令組成。`ARP` 既可以由操作系統處... ...
  • aspnetcore微服務之間通信grpc,一般服務對外介面用restful架構,HTTP請求,服務之間的通信grpc多走內網。 以前寫過一篇grpc和web前端之間的通訊,代碼如下: exercisebook/grpc/grpc-web at main · liuzhixin405/exercis ...
  • 正則表達式是一種用來匹配字元串的規則。每個字元在正則表達式中都有其特定的含義,下麵是一些常見的字元及其含義: 1. ^:匹配字元串的開頭位置。 2. $:匹配字元串的結尾位置。 3. .:匹配任意單個字元。 4. *:匹配0個或多個前面的字元。 5. +:匹配1個或多個前面的字元。 6. ?:匹配0 ...
  • 在我們開發的前端項目中,往往為了方便,都需對一些控制項進行自定義的處理,以便實現快速的數據綁定以及便捷的使用,本篇隨筆介紹通過抽取常見字典列表,實現通用的字典類型綁定;以及通過自定義控制項的屬性處理,實現系統字典內容的快捷綁定的操作。 ...
  • 安裝Ubuntu Linux元信息 兩台機器,每台機器兩台Ubuntu Ubuntu版本:ubuntu-22.04.3-desktop-amd64.iso 處理器數量2,每個處理器的核心數量2,總處理器核心數量4 單個虛擬機記憶體8192MB(8G),最大磁碟大小30G 參考鏈接 清華大學開源軟體鏡像 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...