Sort Bootstrap-Vue table (mon, tue, wed 而不是字母顺序)
Sort Bootstrap-Vue table (mon, tue, wed instead of alphabetical)
我有一个 table 使用 Bootstrap-vue 从数据库中提取信息。数据库有一个名为 "day" 的字段,它存储 "mon"、"tue"、"wed" 等字符串值。我希望能够对 table 进行排序按天而不是按字母顺序按此列。有办法吗?
我对 Vue 和 Bootstrap Vue 还很陌生。我已经设置了 table,它可以很好地从数据库中提取信息。它将每个存储为一个对象,并根据定义的字段显示它。
用于可视化问题的简化代码:
HTML:
<div id='root'>
<b-container fluid>
<h1>Welcome</h1>
<br/>
<b-table
show-empty
stacked="md"
:items="tableItems"
:fields="fields"
sort-by="day"
>
</b-table>
</b-container>
</div>
视觉:
new Vue({
el: '#root',
data() {
return {
tableItems: [
{name: 'Mark', age: '23', day:'wed'},
{name: 'John', age: '21', day:'thu'},
{name: 'Stephen', age: '24', day:'tue'},
{name: 'Will', age: '31', day:'fri'},
{name: 'Andrew', age: '27', day:'wed'},
{name: 'James', age: '24', day:'mon'},
{name: 'Shawn', age: '29', day:'tue'},
],
fields: [
{ key: 'name', label: 'Name', sortable: true},
{ key: 'age', label: 'Age', sortable: true, class: 'text-center' },
{ key: 'day', label: 'Day', sortable: true},
],
}
}
});
目前此代码将在日期列中按字母顺序排序。我希望它按 "date" 排序,例如"mon"、"tue"、"wed"、等等
您可以通过挂接到 :sort-compare
例程来使用您自己的自定义排序方法。
<b-table
show-empty
stacked="md"
:items="tableItems"
:fields="fields"
:sort-compare="sortingChanged"
>
然后定义一个字典来给你的日子值。
const days = {
"sun": 0,
"mon": 1,
"tue": 2,
"wed": 3,
"thu": 4,
"fri": 5,
"sat": 6,
};
最后处理排序。
methods: {
sortingChanged(a, b, key) {
let result = 0;
if (key === 'day') {
let day1 = a[key].toLowerCase();
let day2 = b[key].toLowerCase();
return days[day1] - days[day2];
}
return false;
}
}
数学。min/max 的内容是将 sort-compare
例程正常工作所需的值限制在 -1 和 1 之间。
这是一个working codesandbox example. You can read more about the sort-compare
routine in the docs。
感谢@TroyMorehouse 指出更好的方法。
我有一个 table 使用 Bootstrap-vue 从数据库中提取信息。数据库有一个名为 "day" 的字段,它存储 "mon"、"tue"、"wed" 等字符串值。我希望能够对 table 进行排序按天而不是按字母顺序按此列。有办法吗?
我对 Vue 和 Bootstrap Vue 还很陌生。我已经设置了 table,它可以很好地从数据库中提取信息。它将每个存储为一个对象,并根据定义的字段显示它。
用于可视化问题的简化代码:
HTML:
<div id='root'>
<b-container fluid>
<h1>Welcome</h1>
<br/>
<b-table
show-empty
stacked="md"
:items="tableItems"
:fields="fields"
sort-by="day"
>
</b-table>
</b-container>
</div>
视觉:
new Vue({
el: '#root',
data() {
return {
tableItems: [
{name: 'Mark', age: '23', day:'wed'},
{name: 'John', age: '21', day:'thu'},
{name: 'Stephen', age: '24', day:'tue'},
{name: 'Will', age: '31', day:'fri'},
{name: 'Andrew', age: '27', day:'wed'},
{name: 'James', age: '24', day:'mon'},
{name: 'Shawn', age: '29', day:'tue'},
],
fields: [
{ key: 'name', label: 'Name', sortable: true},
{ key: 'age', label: 'Age', sortable: true, class: 'text-center' },
{ key: 'day', label: 'Day', sortable: true},
],
}
}
});
目前此代码将在日期列中按字母顺序排序。我希望它按 "date" 排序,例如"mon"、"tue"、"wed"、等等
您可以通过挂接到 :sort-compare
例程来使用您自己的自定义排序方法。
<b-table
show-empty
stacked="md"
:items="tableItems"
:fields="fields"
:sort-compare="sortingChanged"
>
然后定义一个字典来给你的日子值。
const days = {
"sun": 0,
"mon": 1,
"tue": 2,
"wed": 3,
"thu": 4,
"fri": 5,
"sat": 6,
};
最后处理排序。
methods: {
sortingChanged(a, b, key) {
let result = 0;
if (key === 'day') {
let day1 = a[key].toLowerCase();
let day2 = b[key].toLowerCase();
return days[day1] - days[day2];
}
return false;
}
}
数学。min/max 的内容是将 sort-compare
例程正常工作所需的值限制在 -1 和 1 之间。
这是一个working codesandbox example. You can read more about the sort-compare
routine in the docs。
感谢@TroyMorehouse 指出更好的方法。