解決vue elementUI中table里數(shù)字、字母、中文混合排序問題
1.使用場景
使用elementUI中的table時,給包含數(shù)字字母中文的名稱等字段排序
例如:數(shù)字(0->9)->大寫字母(A->Z)->小寫字母(a->z)->中文拼音(a->z)
2.代碼解析
<el-table
ref="multipleTable"
border
tooltip-effect="dark"
class="xg-table"
style="width: 100%"
max-height="600">
<el-table-column
type="selection"
width="60" />
<el-table-column
:default-sort = "{prop: 'DevName'}"
:sort-method="sortDevName"
prop="DevName"
label="名稱"
sortable
show-overflow-tooltip />
</el-table>
設(shè)置屬性sortable,會按照自帶的機(jī)制排序,不符合我們的預(yù)期;
所以增加屬性 sort-method,在方法中自定義排序方式
<script>
export default {
methods: {
sortDevName(str1, str2) {
let res = 0
for (let i = 0; ;i++) {
if (!str1[i] || !str2[i]) {
res = str1.length - str2.length
break
}
const char1 = str1[i]
const char1Type = this.getChartType(char1)
const char2 = str2[i]
const char2Type = this.getChartType(char2)
// 類型相同的逐個比較字符
if (char1Type[0] === char2Type[0]) {
if (char1 === char2) {
continue
} else {
if (char1Type[0] === 'zh') {
res = char1.localeCompare(char2)
} else if (char1Type[0] === 'en') {
res = char1.charCodeAt(0) - char2.charCodeAt(0)
} else {
res = char1 - char2
}
break
}
} else {
// 類型不同的,直接用返回的數(shù)字相減
res = char1Type[1] - char2Type[1]
break
}
}
return res
},
getChartType(char) {
// 數(shù)字可按照排序的要求進(jìn)行自定義,我這邊產(chǎn)品的要求是
// 數(shù)字(0->9)->大寫字母(A->Z)->小寫字母(a->z)->中文拼音(a->z)
if (/^[\u4e00-\u9fa5]$/.test(char)) {
return ['zh', 300]
}
if (/^[a-zA-Z]$/.test(char)) {
return ['en', 200]
}
if (/^[0-9]$/.test(char)) {
return ['number', 100]
}
return ['others', 999]
}
}
}
</script>
3.頁面效果
原列表 ==》》 正序 ==》》 倒序



總結(jié)
以上所述是小編給大家介紹的解決vue elementUI中table里數(shù)字、字母、中文混合排序問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
Vue 實現(xiàn)拖動滑塊驗證功能(只有css+js沒有后臺驗證步驟)
這篇文章給大家介紹了基于vue實現(xiàn)拖動滑塊驗證功能,代碼引用css與js都是線上的,將代碼全部復(fù)制到一個html中可以直接打開,超級簡單,感興趣的朋友跟隨腳本之家小編一起看看吧2018-08-08
vue的ElementUI form表單如何給label屬性字符串中添加空白占位符
這篇文章主要介紹了vue的ElementUI form表單如何給label屬性字符串中添加空白占位符問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10
vue項目中created()被調(diào)用多次的踩坑實戰(zhàn)
在vue項目中我在created中調(diào)用了兩次get數(shù)據(jù)請求,所以下面這篇文章主要給大家介紹了關(guān)于vue項目中created()被調(diào)用多次的踩坑實戰(zhàn),需要的朋友可以參考下2023-03-03
Vue列表循環(huán)從指定下標(biāo)開始的多種解決方案
這篇文章主要介紹了Vue列表循環(huán)從指定下標(biāo)開始的多種方案,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04

