Files
vxe-table/examples/views/table/scroll/ScrollRows.vue
xuliangzhan d99fa2a951 fix
2023-08-15 00:03:35 +08:00

270 lines
10 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<template>
<div>
<p class="tip">
虚拟滚动渲染<br>
大数据不建议使用双向绑定的 <table-api-link name="data"/> 属性建议使用 <table-api-link prop="loadData"/>/<table-api-link prop="reloadData"/> 函数<br>
<table-api-link prop="data"/> <table-api-link prop="loadData"/>/<table-api-link prop="reloadData"/> 不应该同时使用请根据数据量决定使用哪种方式保证一致性<br>
<span class="red">启用纵向虚拟滚启动后不支持动态行高如果需要支持将虚拟滚动关闭即可</span>
</p>
<vxe-toolbar>
<template #buttons>
<vxe-button @click="loadList(50)">50条</vxe-button>
<vxe-button @click="loadList(100)">100条</vxe-button>
<vxe-button @click="loadList(1000)">1k条</vxe-button>
<vxe-button @click="loadList(5000)">5k条</vxe-button>
<vxe-button @click="loadList(10000)">1w条</vxe-button>
<vxe-button @click="loadList(50000)">5w条</vxe-button>
<vxe-button @click="loadList(100000)">10w条</vxe-button>
<vxe-button @click="loadList(200000)">20w条</vxe-button>
<vxe-button @click="loadList(300000)">30w条</vxe-button>
</template>
</vxe-toolbar>
<vxe-table
border
resizable
show-overflow
show-header-overflow
ref="xTable"
height="700"
:export-config="{}"
:sort-config="{trigger: 'cell'}"
:loading="demo1.loading"
:scroll-y="{enabled: true}">
<vxe-column type="seq" width="100"></vxe-column>
<vxe-column field="attr0" title="Attr0" sortable width="200"></vxe-column>
<vxe-column field="attr1" title="Attr1" width="200"></vxe-column>
<vxe-column field="attr2" title="Attr2" width="200"></vxe-column>
<vxe-column field="attr3" title="Attr3" width="200"></vxe-column>
<vxe-column field="attr4" title="Attr4" width="200"></vxe-column>
<vxe-column field="attr5" title="Attr5" width="200"></vxe-column>
<vxe-column field="attr6" title="Attr5" width="300"></vxe-column>
<vxe-column field="attr7" title="Attr7" width="200"></vxe-column>
<vxe-column field="attr8" title="Attr8" width="200"></vxe-column>
<vxe-column field="attr9" title="Attr9" width="200"></vxe-column>
<vxe-column field="attr10" title="Attr10" width="200"></vxe-column>
<vxe-column field="attr11" title="Attr11" width="200"></vxe-column>
<vxe-column field="attr12" title="Attr12" width="200"></vxe-column>
<vxe-column field="attr13" title="Attr14" width="200"></vxe-column>
<vxe-column field="attr14" title="Attr14" width="200"></vxe-column>
<vxe-column field="attr15" title="Attr15" width="200"></vxe-column>
<vxe-column field="attr16" title="Attr16" width="200"></vxe-column>
</vxe-table>
<p class="demo-code">{{ $t('app.body.button.showCode') }}</p>
<pre>
<pre-code class="xml">{{ demoCodes[0] }}</pre-code>
<pre-code class="typescript">{{ demoCodes[1] }}</pre-code>
</pre>
</div>
</template>
<script lang="ts">
import { defineComponent, nextTick, reactive, ref } from 'vue'
import { VXETable } from '../../../../packages/all'
import { VxeTableInstance } from '../../../../types/index'
import XEUtils from 'xe-utils'
const dataList: any[] = []
export default defineComponent({
setup () {
const demo1 = reactive({
loading: false,
tableData: []
})
const xTable = ref({} as VxeTableInstance)
const mockList = (rowSize: number): Promise<any[]> => {
return new Promise(resolve => {
setTimeout(() => {
const currSize = dataList.length
if (currSize < rowSize) {
for (let i = currSize; i < rowSize; i++) {
dataList.push({
checked: false,
attr0: 'attr0_row_' + i,
attr1: 'attr1_row_' + i,
attr2: 'attr2_row_' + i,
attr3: 'attr3_row_' + i,
attr4: 'attr4_row_' + i,
attr5: 'attr5_row_' + i,
attr6: 'attr6_row_' + i,
attr7: 'attr7_row_' + i,
attr8: 'attr8_row_' + i,
attr9: 'attr9_row_' + i,
attr10: 'attr10_row_' + i,
attr11: 'attr11_row_' + i,
attr12: 'attr12_row_' + i,
attr13: 'attr13_row_' + i,
attr14: 'attr14_row_' + i,
attr15: 'attr15_row_' + i,
attr16: 'attr16_row_' + i
})
}
}
const result = XEUtils.clone(dataList.slice(0, rowSize), true)
resolve(result)
}, 100)
})
}
const loadList = (rowSize: number) => {
demo1.loading = true
mockList(rowSize).then(data => {
const startTime = Date.now()
const $table = xTable.value
// 使用函数式加载
if ($table) {
$table.reloadData(data).then(() => {
VXETable.modal.message({ content: `渲染 ${rowSize} 行,用时 ${Date.now() - startTime}毫秒`, status: 'info' })
demo1.loading = false
})
} else {
demo1.loading = false
}
})
}
nextTick(() => {
loadList(600)
})
return {
xTable,
demo1,
loadList,
demoCodes: [
`
<vxe-toolbar>
<template #buttons>
<vxe-button @click="loadList(50)">50条</vxe-button>
<vxe-button @click="loadList(100)">100条</vxe-button>
<vxe-button @click="loadList(1000)">1k条</vxe-button>
<vxe-button @click="loadList(5000)">5k条</vxe-button>
<vxe-button @click="loadList(10000)">1w条</vxe-button>
<vxe-button @click="loadList(50000)">5w条</vxe-button>
<vxe-button @click="loadList(100000)">10w条</vxe-button>
<vxe-button @click="loadList(200000)">20w条</vxe-button>
<vxe-button @click="loadList(300000)">30w条</vxe-button>
</template>
</vxe-toolbar>
<vxe-table
border
resizable
show-overflow
show-header-overflow
ref="xTable"
height="700"
:export-config="{}"
:sort-config="{trigger: 'cell'}"
:loading="demo1.loading">
<vxe-column type="seq" width="100"></vxe-column>
<vxe-column field="attr0" title="Attr0" sortable width="200"></vxe-column>
<vxe-column field="attr1" title="Attr1" width="200"></vxe-column>
<vxe-column field="attr2" title="Attr2" width="200"></vxe-column>
<vxe-column field="attr3" title="Attr3" width="200"></vxe-column>
<vxe-column field="attr4" title="Attr4" width="200"></vxe-column>
<vxe-column field="attr5" title="Attr5" width="200"></vxe-column>
<vxe-column field="attr6" title="Attr5" width="300"></vxe-column>
<vxe-column field="attr7" title="Attr7" width="200"></vxe-column>
<vxe-column field="attr8" title="Attr8" width="200"></vxe-column>
<vxe-column field="attr9" title="Attr9" width="200"></vxe-column>
<vxe-column field="attr10" title="Attr10" width="200"></vxe-column>
<vxe-column field="attr11" title="Attr11" width="200"></vxe-column>
<vxe-column field="attr12" title="Attr12" width="200"></vxe-column>
<vxe-column field="attr13" title="Attr14" width="200"></vxe-column>
<vxe-column field="attr14" title="Attr14" width="200"></vxe-column>
<vxe-column field="attr15" title="Attr15" width="200"></vxe-column>
<vxe-column field="attr16" title="Attr16" width="200"></vxe-column>
</vxe-table>
`,
`
import { defineComponent, nextTick, reactive, ref } from 'vue'
import { VXETable, VxeTableInstance } from '../../../../types/index'
import XEUtils from 'xe-utils'
const dataList: any[] = []
export default defineComponent({
setup () {
const demo1 = reactive({
loading: false,
tableData: []
})
const xTable = ref({} as VxeTableInstance)
const mockList = (rowSize: number): Promise<any[]> => {
return new Promise(resolve => {
setTimeout(() => {
const currSize = dataList.length
if (currSize < rowSize) {
for (let i = currSize; i < rowSize; i++) {
dataList.push({
checked: false,
attr0: 'attr0_row_' + i,
attr1: 'attr1_row_' + i,
attr2: 'attr2_row_' + i,
attr3: 'attr3_row_' + i,
attr4: 'attr4_row_' + i,
attr5: 'attr5_row_' + i,
attr6: 'attr6_row_' + i,
attr7: 'attr7_row_' + i,
attr8: 'attr8_row_' + i,
attr9: 'attr9_row_' + i,
attr10: 'attr10_row_' + i,
attr11: 'attr11_row_' + i,
attr12: 'attr12_row_' + i,
attr13: 'attr13_row_' + i,
attr14: 'attr14_row_' + i,
attr15: 'attr15_row_' + i,
attr16: 'attr16_row_' + i
})
}
}
const result = XEUtils.clone(dataList.slice(0, rowSize), true)
resolve(result)
}, 100)
})
}
const loadList = (rowSize: number) => {
demo1.loading = true
mockList(rowSize).then(data => {
const startTime = Date.now()
const $table = xTable.value
// 使用函数式加载
if ($table) {
$table.reloadData(data).then(() => {
VXETable.modal.message({ content: \`渲染 \${rowSize} 行,用时 \${Date.now() - startTime}毫秒\`, status: 'info' })
demo1.loading = false
})
} else {
demo1.loading = false
}
})
}
nextTick(() => {
loadList(600)
})
return {
xTable,
demo1,
loadList
}
}
}
`
]
}
}
})
</script>