一份 ElementUI 問題清單
點擊上方 前端瓶子君,關注公眾號
回復算法,加入前端編程面試算法每日一題群

1、form 下面只有一個 input 時回車鍵刷新頁面
原因是觸發(fā)了表單默認的提交行為,給el-form 加上@submit.native.prevent就行了。
<el-form inline @submit.native.prevent>
<el-form-item label="訂單號">
<el-input
v-model="query.orderNo"
:placeholder="輸入訂單號查詢"
clearable
@keyup.enter.native="enterInput"
/>
</el-form-item>
</el-form>
復制代碼
2、表格固定列最后一行顯示不全
這種情況有時在寬度剛好處于臨界值狀態(tài)時會出現(xiàn)。因為固定列是獨立于表格body動態(tài)計算高度的,出現(xiàn)了固定列高度小于表格高度所以造成最后一行被遮擋。
// 設置全局
.el-table__fixed-right {
height: 100% !important;
}
復制代碼
3、氣泡確認框文檔里的confirm事件不生效
版本:element-ui: "2.13.2", vue: "2.6.10"
// 將confirm改為onConfirm
@onConfirm="onDeleteOrder(row.id)"
復制代碼
4、輸入框用正則限制但綁定值未更新
看到項目里有下面這么一段代碼:
<el-input
v-model="form.retailMinOrder"
placeholder="請輸入"
onkeyup="value=value.replace(/[^\d.]/g,'')"
/>
復制代碼
這樣做雖然輸入框的顯示是正確的,但綁定的值是沒有更新的,將 onkeyup 改為 oninput 即可。
-
PS:經評論區(qū)的兄弟指正,輸入中文后 v-model 會失效,下面的方式更好一點:
<el-input
v-model="form.retailMinOrder"
placeholder="請輸入"
@keyup.native="form.retailMinOrder=form.retailMinOrder.replace(/[^\d.]/g,'')"
/>
復制代碼
5、去除type="number"輸入框聚焦時的上下箭頭
/* 設置全局 */
.clear-number-input.el-input::-webkit-outer-spin-button,
.clear-number-input.el-input::-webkit-inner-spin-button {
margin: 0;
-webkit-appearance: none !important;
}
.clear-number-input.el-input input[type="number"]::-webkit-outer-spin-button,
.clear-number-input.el-input input[type="number"]::-webkit-inner-spin-button {
margin: 0;
-webkit-appearance: none !important;
}
.clear-number-input.el-input {
-moz-appearance: textfield;
}
.clear-number-input.el-input input[type="number"] {
-moz-appearance: textfield;
}
復制代碼
<el-input type="number" class="clear-number-input" />
復制代碼
6、只校驗表單其中一個字段
在一些用戶注冊場景中,提交整個表單前有時候我們會做一些單獨字段的校驗,例如發(fā)送手機驗證碼,發(fā)送時我們只需要校驗手機號碼這個字段,可以這樣做:
this.$refs['form'].validateField('mobile', valid => {
if (valid) {
// 發(fā)送驗證碼
}
})
復制代碼
如果需要多個參數(shù),將參數(shù)改為數(shù)組形式即可。
7、彈窗重新打開時表單上次的校驗信息未清除
有人會在open時在$nextTick里重置表單,而我選擇在關閉時進行重置。
<el-dialog @close="onClose">
<el-form ref="form">
</el-form>
</el-dialog>
// 彈窗關閉時重置表單
onClose() {
this.$refs['form'].resetFields()
}
復制代碼
8、表頭與內容錯位
網上也有其他一些辦法,但我記得對我沒什么作用,后來我是用下面這個辦法:
// 全局設置
.el-table--scrollable-y .el-table__body-wrapper {
overflow-y: overlay !important;
}
復制代碼
9、表單多級數(shù)據(jù)結構校驗問題
<el-form :model="form">
<el-form-item label="部門" prop="dept"></el-form-item>
<el-form-item label="姓名" prop="user.name"></el-form-item>
</el-form>
復制代碼
rules: {
'user.name': [{ required: true, message: '姓名不能為空', trigger: 'blur' }]
}
復制代碼
10、表格跨分頁多選
看到項目里有小伙伴手動添加代碼去處理這個問題,其實根據(jù)文檔,只需加上row-key和reserve-selection即可。
<el-table row-key="id">
<el-table-column type="selection" reserve-selection></el-table-column>
</el-table>
復制代碼
11、根據(jù)條件高亮行并去除默認hover顏色
<el-table :row-class-name="tableRowClassName">
</el-table>
tableRowClassName({ row }) {
return row.status === 2 ? 'highlight' : ''
}
// 設置全局
.el-table .highlight {
background-color: #b6e8fe;
&:hover > td {
background-color: initial !important;
}
td {
background-color: initial !important;
}
}
復制代碼
12、表單不想顯示label但又想顯示必填星號怎么辦
// label給個空格即可
<el-form>
<el-table>
<el-table-column label="名稱">
<template>
<el-form-item label=" ">
<el-input placeholder="名稱不能為空" />
</el-form-item>
</template>
</el-table-column>
</el-table>
</el-form>
復制代碼
13、table 內嵌 input 調用 focus 方法無效
<el-table>
<el-table-column label="名稱">
<template>
<el-input ref="inputRef" />
</template>
</el-table-column>
</el-table>
// 無效
this.$refs['inputRef'].focus()
this.$refs['inputRef'][0].focus()
this.$refs['inputRef'].$el.children[0].focus()
// 有效
<el-input id="inputRef" />
document.getElementById('inputRef').focus()
復制代碼
14、表格內容超出省略
看到有小伙伴在代碼里自己手動去添加CSS來實現(xiàn),害,又是一個不看文檔的反面例子,其實只要加個show-overflow-tooltip就可以了,還自帶tooltip效果,不香嗎?
<el-table-column label="客戶名稱" prop="customerName" show-overflow-tooltip>
</el-table-column>
復制代碼
15、el-tree 展開/收起所有節(jié)點
<el-tree ref="tree"></el-tree>
expandTree(expand = true) {
const nodes = this.$refs['tree'].store._getAllNodes()
nodes.forEach(node => {
node.expanded = expand
})
}
復制代碼
16、哪天想起什么或遇到什么再更新。。。
關于本文
作者:8號的凌晨4點
https://juejin.cn/post/6981083988286767117
最后
評論
圖片
表情
