解决vueelementUI中table⾥数字、字母、中⽂混合排序
问题
1.使⽤场景
使⽤elementUI中的table时,给包含数字字母中⽂的名称等字段排序
例如:数字(0->9)->⼤写字母(A->Z)->⼩写字母(a->z)->中⽂拼⾳(a->z)
2.代码解析
<el-table
ref="multipleTable"
border
tooltip-effect="dark"
class="xg-table"
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>
设置属性sortable,会按照⾃带的机制排序,不符合我们的预期;
所以增加属性 sort-method,在⽅法中⾃定义排序⽅式
electron vue教程<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 = ChartType(char1)
const char2 = str2[i]
const char2Type = ChartType(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 {
/
/ 类型不同的,直接⽤返回的数字相减
res = char1Type[1] - char2Type[1]
break
}
}
return res
},
getChartType(char) {
// 数字可按照排序的要求进⾏⾃定义,我这边产品的要求是
// 数字(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.页⾯效果
原列表                  ==》》正序                ==》》倒序
总结
以上所述是⼩编给⼤家介绍的解决vue elementUI中table⾥数字、字母、中⽂混合排序问题,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!
如果你觉得本⽂对你有帮助,欢迎转载,烦请注明出处,谢谢!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。