vxe-table 4.18.0 → 4.18.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/style.css +1 -1
- package/es/table/src/column.js +1 -1
- package/es/table/src/group.js +2 -1
- package/es/table/src/table.js +14 -11
- package/es/ui/index.js +1 -1
- package/es/ui/src/log.js +1 -1
- package/lib/index.umd.js +8 -7
- package/lib/index.umd.min.js +1 -1
- package/lib/style.css +1 -1
- package/lib/table/src/column.js +1 -1
- package/lib/table/src/column.min.js +1 -1
- package/lib/table/src/group.js +2 -1
- package/lib/table/src/group.min.js +1 -1
- package/lib/table/src/table.js +3 -3
- package/lib/table/src/table.min.js +1 -1
- package/lib/ui/index.js +1 -1
- package/lib/ui/index.min.js +1 -1
- package/lib/ui/src/log.js +1 -1
- package/lib/ui/src/log.min.js +1 -1
- package/package.json +1 -1
- package/packages/table/src/column.ts +1 -1
- package/packages/table/src/group.ts +2 -1
- package/packages/table/src/table.ts +14 -11
- /package/es/{iconfont.1773027275628.ttf → iconfont.1773109208977.ttf} +0 -0
- /package/es/{iconfont.1773027275628.woff → iconfont.1773109208977.woff} +0 -0
- /package/es/{iconfont.1773027275628.woff2 → iconfont.1773109208977.woff2} +0 -0
- /package/lib/{iconfont.1773027275628.ttf → iconfont.1773109208977.ttf} +0 -0
- /package/lib/{iconfont.1773027275628.woff → iconfont.1773109208977.woff} +0 -0
- /package/lib/{iconfont.1773027275628.woff2 → iconfont.1773109208977.woff2} +0 -0
package/es/table/src/column.js
CHANGED
package/es/table/src/group.js
CHANGED
|
@@ -31,9 +31,10 @@ export default defineVxeComponent({
|
|
|
31
31
|
destroyColumn($xeTable, columnConfig);
|
|
32
32
|
});
|
|
33
33
|
const renderVN = () => {
|
|
34
|
+
const defaultSlot = slots.default;
|
|
34
35
|
return h('div', {
|
|
35
36
|
ref: refElem
|
|
36
|
-
},
|
|
37
|
+
}, defaultSlot ? defaultSlot() : []);
|
|
37
38
|
};
|
|
38
39
|
const $xeColgroup = { columnConfig };
|
|
39
40
|
provide('$xeColgroup', $xeColgroup);
|
package/es/table/src/table.js
CHANGED
|
@@ -5104,7 +5104,7 @@ export default defineVxeComponent({
|
|
|
5104
5104
|
cellLabel = tcFormatMethod ? tcFormatMethod(formatParams, ...formatter.slice(1)) : '';
|
|
5105
5105
|
}
|
|
5106
5106
|
else {
|
|
5107
|
-
cellLabel =
|
|
5107
|
+
cellLabel = formatter(formatParams);
|
|
5108
5108
|
}
|
|
5109
5109
|
}
|
|
5110
5110
|
else if (renderOpts && tcFormatter) {
|
|
@@ -10043,6 +10043,7 @@ export default defineVxeComponent({
|
|
|
10043
10043
|
if (!checkMethod || checkMethod({ $table: $xeTable, row })) {
|
|
10044
10044
|
let newValue = row;
|
|
10045
10045
|
let isChange = oldValue !== newValue;
|
|
10046
|
+
const selected = !isChange;
|
|
10046
10047
|
if (isChange) {
|
|
10047
10048
|
handleCheckedRadioRow(newValue);
|
|
10048
10049
|
}
|
|
@@ -10054,7 +10055,7 @@ export default defineVxeComponent({
|
|
|
10054
10055
|
}
|
|
10055
10056
|
}
|
|
10056
10057
|
if (isChange) {
|
|
10057
|
-
dispatchEvent('radio-change', Object.assign({ oldValue, newValue }, params), evnt);
|
|
10058
|
+
dispatchEvent('radio-change', Object.assign({ oldValue, newValue, selected }, params), evnt);
|
|
10058
10059
|
}
|
|
10059
10060
|
}
|
|
10060
10061
|
},
|
|
@@ -10063,7 +10064,7 @@ export default defineVxeComponent({
|
|
|
10063
10064
|
const columnOpts = computeColumnOpts.value;
|
|
10064
10065
|
const currentColumnOpts = computeCurrentColumnOpts.value;
|
|
10065
10066
|
const beforeRowMethod = currentColumnOpts.beforeSelectMethod || columnOpts.currentMethod;
|
|
10066
|
-
|
|
10067
|
+
let { column: newValue } = params;
|
|
10067
10068
|
const { trigger, strict } = currentColumnOpts;
|
|
10068
10069
|
if (trigger === 'manual') {
|
|
10069
10070
|
return;
|
|
@@ -10075,8 +10076,9 @@ export default defineVxeComponent({
|
|
|
10075
10076
|
$xeTable.setCurrentColumn(newValue);
|
|
10076
10077
|
}
|
|
10077
10078
|
else {
|
|
10078
|
-
isChange =
|
|
10079
|
-
if (
|
|
10079
|
+
isChange = oldValue === newValue;
|
|
10080
|
+
if (isChange) {
|
|
10081
|
+
newValue = null;
|
|
10080
10082
|
$xeTable.clearCurrentColumn();
|
|
10081
10083
|
}
|
|
10082
10084
|
else {
|
|
@@ -10084,7 +10086,7 @@ export default defineVxeComponent({
|
|
|
10084
10086
|
}
|
|
10085
10087
|
}
|
|
10086
10088
|
if (isChange) {
|
|
10087
|
-
dispatchEvent('current-column-change', Object.assign({ oldValue, newValue }, params), evnt);
|
|
10089
|
+
dispatchEvent('current-column-change', Object.assign({ oldValue, newValue, selected }, params), evnt);
|
|
10088
10090
|
}
|
|
10089
10091
|
}
|
|
10090
10092
|
else {
|
|
@@ -10096,7 +10098,7 @@ export default defineVxeComponent({
|
|
|
10096
10098
|
const rowOpts = computeRowOpts.value;
|
|
10097
10099
|
const currentRowOpts = computeCurrentRowOpts.value;
|
|
10098
10100
|
const beforeRowMethod = currentRowOpts.beforeSelectMethod || rowOpts.currentMethod;
|
|
10099
|
-
|
|
10101
|
+
let { row: newValue } = params;
|
|
10100
10102
|
const { trigger, strict } = currentRowOpts;
|
|
10101
10103
|
if (trigger === 'manual') {
|
|
10102
10104
|
return;
|
|
@@ -10108,8 +10110,9 @@ export default defineVxeComponent({
|
|
|
10108
10110
|
$xeTable.setCurrentRow(newValue);
|
|
10109
10111
|
}
|
|
10110
10112
|
else {
|
|
10111
|
-
isChange =
|
|
10112
|
-
if (
|
|
10113
|
+
isChange = oldValue === newValue;
|
|
10114
|
+
if (isChange) {
|
|
10115
|
+
newValue = null;
|
|
10113
10116
|
$xeTable.clearCurrentRow();
|
|
10114
10117
|
}
|
|
10115
10118
|
else {
|
|
@@ -10117,9 +10120,9 @@ export default defineVxeComponent({
|
|
|
10117
10120
|
}
|
|
10118
10121
|
}
|
|
10119
10122
|
if (isChange) {
|
|
10120
|
-
dispatchEvent('current-row-change', Object.assign({ oldValue, newValue }, params), evnt);
|
|
10123
|
+
dispatchEvent('current-row-change', Object.assign({ oldValue, newValue, selected }, params), evnt);
|
|
10121
10124
|
// 已废弃
|
|
10122
|
-
dispatchEvent('current-change', Object.assign({ oldValue, newValue }, params), evnt);
|
|
10125
|
+
dispatchEvent('current-change', Object.assign({ oldValue, newValue, selected }, params), evnt);
|
|
10123
10126
|
}
|
|
10124
10127
|
}
|
|
10125
10128
|
else {
|
package/es/ui/index.js
CHANGED
package/es/ui/src/log.js
CHANGED
package/lib/index.umd.js
CHANGED
|
@@ -3144,7 +3144,7 @@ function getDefaultConfig(val1, def1) {
|
|
|
3144
3144
|
;// ./packages/ui/index.ts
|
|
3145
3145
|
|
|
3146
3146
|
|
|
3147
|
-
const version = "4.18.
|
|
3147
|
+
const version = "4.18.1";
|
|
3148
3148
|
core_.VxeUI.version = version;
|
|
3149
3149
|
core_.VxeUI.tableVersion = version;
|
|
3150
3150
|
core_.VxeUI.setConfig({
|
|
@@ -3668,7 +3668,7 @@ var esnext_iterator_some = __webpack_require__(7550);
|
|
|
3668
3668
|
const {
|
|
3669
3669
|
log: log_log
|
|
3670
3670
|
} = core_.VxeUI;
|
|
3671
|
-
const log_version = `table v${"4.18.
|
|
3671
|
+
const log_version = `table v${"4.18.1"}`;
|
|
3672
3672
|
const warnLog = log_log.create('warn', log_version);
|
|
3673
3673
|
const errLog = log_log.create('error', log_version);
|
|
3674
3674
|
;// ./packages/table/src/columnInfo.ts
|
|
@@ -6970,7 +6970,7 @@ const columnProps = {
|
|
|
6970
6970
|
// 内容渲染配置项
|
|
6971
6971
|
contentRender: Object,
|
|
6972
6972
|
// 聚合函数
|
|
6973
|
-
aggFunc: [
|
|
6973
|
+
aggFunc: [Boolean, String],
|
|
6974
6974
|
// 将单元格复制到剪贴板
|
|
6975
6975
|
copyMethod: Function,
|
|
6976
6976
|
// 将剪贴单元格的值清除
|
|
@@ -7073,9 +7073,10 @@ const Column = VxeColumn;
|
|
|
7073
7073
|
destroyColumn($xeTable, columnConfig);
|
|
7074
7074
|
});
|
|
7075
7075
|
const renderVN = () => {
|
|
7076
|
+
const defaultSlot = slots.default;
|
|
7076
7077
|
return (0,external_commonjs_vue_commonjs2_vue_root_Vue_.h)('div', {
|
|
7077
7078
|
ref: refElem
|
|
7078
|
-
},
|
|
7079
|
+
}, defaultSlot ? defaultSlot() : []);
|
|
7079
7080
|
};
|
|
7080
7081
|
const $xeColgroup = {
|
|
7081
7082
|
columnConfig
|
|
@@ -19852,7 +19853,7 @@ if(virtualXOpts.scrollToLeftOnChange){targetScrollLeft=0;}if(virtualYOpts.scroll
|
|
|
19852
19853
|
* @param {Array/Row} rows 行数据
|
|
19853
19854
|
* @param {String} field 字段名
|
|
19854
19855
|
*/clearData(rows,field){const{tableFullData,visibleColumn}=internalData;if(!arguments.length){rows=tableFullData;}else if(rows&&!external_root_XEUtils_commonjs_xe_utils_commonjs2_xe_utils_amd_xe_utils_default().isArray(rows)){rows=[rows];}if(field){rows.forEach(row=>external_root_XEUtils_commonjs_xe_utils_commonjs2_xe_utils_amd_xe_utils_default().set(row,field,null));}else{rows.forEach(row=>{visibleColumn.forEach(column=>{if(column.field){setCellValue(row,column,null);}});});}return (0,external_commonjs_vue_commonjs2_vue_root_Vue_.nextTick)();},getCellElement(row,fieldOrColumn){const{elemStore}=internalData;const column=handleFieldOrColumn($xeTable,fieldOrColumn);if(!column){return null;}const rowid=getRowid($xeTable,row);const bodyScrollElem=getRefElem(elemStore['main-body-scroll']);const leftScrollElem=getRefElem(elemStore['left-body-scroll']);const rightScrollElem=getRefElem(elemStore['right-body-scroll']);let bodyElem;if(column){if(column.fixed){if(column.fixed==='left'){if(leftScrollElem){bodyElem=leftScrollElem;}}else{if(rightScrollElem){bodyElem=rightScrollElem;}}}if(!bodyElem){bodyElem=bodyScrollElem;}if(bodyElem){return bodyElem.querySelector(`.vxe-body--row[rowid="${rowid}"] .${column.id}`);}}return null;},getCellLabel(row,fieldOrColumn){const column=handleFieldOrColumn($xeTable,fieldOrColumn);if(!column){return null;}const{editConfig}=props;const{formatter,editRender,cellRender}=column;// formatter > tableCellFormatter
|
|
19855
|
-
const renderOpts=formatter?null:editConfig&&isEnableConf(editRender)?editRender:isEnableConf(cellRender)?cellRender:null;const compConf=renderOpts?table_renderer.get(renderOpts.name):null;const tcFormatter=compConf?compConf.tableCellFormatter:null;const cellValue=getCellValue(row,column);let cellLabel=cellValue;if(formatter||tcFormatter){let formatData;const{fullAllDataRowIdData}=internalData;const rowid=getRowid($xeTable,row);const colid=column.id;const rowRest=fullAllDataRowIdData[rowid];if(rowRest){formatData=rowRest.formatData;if(!formatData){formatData=fullAllDataRowIdData[rowid].formatData={};}if(rowRest&&formatData[colid]){if(formatData[colid].value===cellValue){return formatData[colid].label;}}}const formatParams={$table:$xeTable,cellValue,row,rowIndex:$xeTable.getRowIndex(row),column,columnIndex:$xeTable.getColumnIndex(column)};if(formatter){if(external_root_XEUtils_commonjs_xe_utils_commonjs2_xe_utils_amd_xe_utils_default().isString(formatter)){const gFormatOpts=table_formats.get(formatter);const tcFormatMethod=gFormatOpts?gFormatOpts.tableCellFormatMethod||gFormatOpts.cellFormatMethod:null;cellLabel=tcFormatMethod?tcFormatMethod(formatParams):'';}else if(external_root_XEUtils_commonjs_xe_utils_commonjs2_xe_utils_amd_xe_utils_default().isArray(formatter)){const gFormatOpts=table_formats.get(formatter[0]);const tcFormatMethod=gFormatOpts?gFormatOpts.tableCellFormatMethod||gFormatOpts.cellFormatMethod:null;cellLabel=tcFormatMethod?tcFormatMethod(formatParams,...formatter.slice(1)):'';}else{cellLabel
|
|
19856
|
+
const renderOpts=formatter?null:editConfig&&isEnableConf(editRender)?editRender:isEnableConf(cellRender)?cellRender:null;const compConf=renderOpts?table_renderer.get(renderOpts.name):null;const tcFormatter=compConf?compConf.tableCellFormatter:null;const cellValue=getCellValue(row,column);let cellLabel=cellValue;if(formatter||tcFormatter){let formatData;const{fullAllDataRowIdData}=internalData;const rowid=getRowid($xeTable,row);const colid=column.id;const rowRest=fullAllDataRowIdData[rowid];if(rowRest){formatData=rowRest.formatData;if(!formatData){formatData=fullAllDataRowIdData[rowid].formatData={};}if(rowRest&&formatData[colid]){if(formatData[colid].value===cellValue){return formatData[colid].label;}}}const formatParams={$table:$xeTable,cellValue,row,rowIndex:$xeTable.getRowIndex(row),column,columnIndex:$xeTable.getColumnIndex(column)};if(formatter){if(external_root_XEUtils_commonjs_xe_utils_commonjs2_xe_utils_amd_xe_utils_default().isString(formatter)){const gFormatOpts=table_formats.get(formatter);const tcFormatMethod=gFormatOpts?gFormatOpts.tableCellFormatMethod||gFormatOpts.cellFormatMethod:null;cellLabel=tcFormatMethod?tcFormatMethod(formatParams):'';}else if(external_root_XEUtils_commonjs_xe_utils_commonjs2_xe_utils_amd_xe_utils_default().isArray(formatter)){const gFormatOpts=table_formats.get(formatter[0]);const tcFormatMethod=gFormatOpts?gFormatOpts.tableCellFormatMethod||gFormatOpts.cellFormatMethod:null;cellLabel=tcFormatMethod?tcFormatMethod(formatParams,...formatter.slice(1)):'';}else{cellLabel=formatter(formatParams);}}else if(renderOpts&&tcFormatter){cellLabel=tcFormatter(renderOpts,formatParams);}if(formatData){formatData[colid]={value:cellValue,label:cellLabel};}}return cellLabel;},getFooterCellLabel(row,fieldOrColumn){const column=handleFieldOrColumn($xeTable,fieldOrColumn);if(!column){return null;}const{footerFormatter}=column;const _columnIndex=$xeTable.getVTColumnIndex(column);let itemValue='';// 兼容老模式
|
|
19856
19857
|
if(external_root_XEUtils_commonjs_xe_utils_commonjs2_xe_utils_amd_xe_utils_default().isArray(row)){itemValue=row[_columnIndex];}else{itemValue=external_root_XEUtils_commonjs_xe_utils_commonjs2_xe_utils_amd_xe_utils_default().get(row,column.field);}let cellLabel=itemValue;if(footerFormatter){let formatData;const{footerTableData}=reactData;const{footerFullDataRowData}=internalData;const colid=column.id;const $rowIndex=footerTableData.indexOf(row);let rowRest=null;if($rowIndex>-1){rowRest=footerFullDataRowData[$rowIndex];if(!rowRest){rowRest=footerFullDataRowData[$rowIndex]={};}formatData=rowRest.formatData;if(!formatData){formatData=footerFullDataRowData[$rowIndex].formatData={};}if(rowRest&&formatData[colid]){if(formatData[colid].value===itemValue){return formatData[colid].label;}}}const footerFormatParams={$table:$xeTable,cellValue:itemValue,itemValue,row,items:row,$rowIndex,column,_columnIndex,columnIndex:$xeTable.getColumnIndex(column)};if(external_root_XEUtils_commonjs_xe_utils_commonjs2_xe_utils_amd_xe_utils_default().isString(footerFormatter)){const gFormatOpts=table_formats.get(footerFormatter);const fcFormatMethod=gFormatOpts?gFormatOpts.tableFooterCellFormatMethod:null;cellLabel=fcFormatMethod?fcFormatMethod(footerFormatParams):'';}else if(external_root_XEUtils_commonjs_xe_utils_commonjs2_xe_utils_amd_xe_utils_default().isArray(footerFormatter)){const gFormatOpts=table_formats.get(footerFormatter[0]);const fcFormatMethod=gFormatOpts?gFormatOpts.tableFooterCellFormatMethod:null;cellLabel=fcFormatMethod?fcFormatMethod(footerFormatParams,...footerFormatter.slice(1)):'';}else{cellLabel=footerFormatter(footerFormatParams);}if(formatData){formatData[colid]={value:itemValue,label:cellLabel};}}return cellLabel;},/**
|
|
19857
19858
|
* 检查是否为临时行数据
|
|
19858
19859
|
*/isInsertByRow(row){const rowid=getRowid($xeTable,row);return!!reactData.insertRowFlag&&!!internalData.insertRowMaps[rowid];},isRemoveByRow(row){const rowid=getRowid($xeTable,row);return!!reactData.removeRowFlag&&!!internalData.removeRowMaps[rowid];},/**
|
|
@@ -20265,8 +20266,8 @@ if(isEnableConf(editConfig)&&editOpts.trigger==='dblclick'){if(actived.row&&acti
|
|
|
20265
20266
|
* 多选,选中所有事件
|
|
20266
20267
|
*/triggerCheckAllEvent(evnt,value){const checkboxOpts=computeCheckboxOpts.value;const{trigger}=checkboxOpts;if(trigger==='manual'){return;}if(evnt){evnt.stopPropagation();}handleCheckAllEvent(evnt,value);},/**
|
|
20267
20268
|
* 单选,行选中事件
|
|
20268
|
-
*/triggerRadioRowEvent(evnt,params){const{selectRadioRow:oldValue}=reactData;const{row}=params;const radioOpts=computeRadioOpts.value;const{trigger,strict,checkMethod}=radioOpts;if(trigger==='manual'){return;}evnt.stopPropagation();if(!checkMethod||checkMethod({$table:$xeTable,row})){let newValue=row;let isChange=oldValue!==newValue;if(isChange){handleCheckedRadioRow(newValue);}else if(!strict){isChange=oldValue===newValue;if(isChange){newValue=null;$xeTable.clearRadioRow();}}if(isChange){dispatchEvent('radio-change',{oldValue,newValue,...params},evnt);}}},triggerCurrentColumnEvent(evnt,params){const{currentColumn:oldValue}=reactData;const columnOpts=computeColumnOpts.value;const currentColumnOpts=computeCurrentColumnOpts.value;const beforeRowMethod=currentColumnOpts.beforeSelectMethod||columnOpts.currentMethod;
|
|
20269
|
-
dispatchEvent('current-change',{oldValue,newValue,...params},evnt);}}else{dispatchEvent('current-row-disabled',params,evnt);}},/**
|
|
20269
|
+
*/triggerRadioRowEvent(evnt,params){const{selectRadioRow:oldValue}=reactData;const{row}=params;const radioOpts=computeRadioOpts.value;const{trigger,strict,checkMethod}=radioOpts;if(trigger==='manual'){return;}evnt.stopPropagation();if(!checkMethod||checkMethod({$table:$xeTable,row})){let newValue=row;let isChange=oldValue!==newValue;const selected=!isChange;if(isChange){handleCheckedRadioRow(newValue);}else if(!strict){isChange=oldValue===newValue;if(isChange){newValue=null;$xeTable.clearRadioRow();}}if(isChange){dispatchEvent('radio-change',{oldValue,newValue,selected,...params},evnt);}}},triggerCurrentColumnEvent(evnt,params){const{currentColumn:oldValue}=reactData;const columnOpts=computeColumnOpts.value;const currentColumnOpts=computeCurrentColumnOpts.value;const beforeRowMethod=currentColumnOpts.beforeSelectMethod||columnOpts.currentMethod;let{column:newValue}=params;const{trigger,strict}=currentColumnOpts;if(trigger==='manual'){return;}let isChange=oldValue!==newValue;const selected=!isChange;if(!beforeRowMethod||beforeRowMethod({column:newValue,selected,$table:$xeTable})){if(strict){$xeTable.setCurrentColumn(newValue);}else{isChange=oldValue===newValue;if(isChange){newValue=null;$xeTable.clearCurrentColumn();}else{$xeTable.setCurrentColumn(newValue);}}if(isChange){dispatchEvent('current-column-change',{oldValue,newValue,selected,...params},evnt);}}else{dispatchEvent('current-column-disabled',params,evnt);}},triggerCurrentRowEvent(evnt,params){const{currentRow:oldValue}=reactData;const rowOpts=computeRowOpts.value;const currentRowOpts=computeCurrentRowOpts.value;const beforeRowMethod=currentRowOpts.beforeSelectMethod||rowOpts.currentMethod;let{row:newValue}=params;const{trigger,strict}=currentRowOpts;if(trigger==='manual'){return;}let isChange=oldValue!==newValue;const selected=!isChange;if(!beforeRowMethod||beforeRowMethod({row:newValue,selected,$table:$xeTable})){if(strict){$xeTable.setCurrentRow(newValue);}else{isChange=oldValue===newValue;if(isChange){newValue=null;$xeTable.clearCurrentRow();}else{$xeTable.setCurrentRow(newValue);}}if(isChange){dispatchEvent('current-row-change',{oldValue,newValue,selected,...params},evnt);// 已废弃
|
|
20270
|
+
dispatchEvent('current-change',{oldValue,newValue,selected,...params},evnt);}}else{dispatchEvent('current-row-disabled',params,evnt);}},/**
|
|
20270
20271
|
* 展开行事件
|
|
20271
20272
|
*/triggerRowExpandEvent(evnt,params){const{expandColumn}=reactData;const{rowExpandLazyLoadedMaps}=internalData;const expandOpts=computeExpandOpts.value;const{row}=params;const{lazy,trigger}=expandOpts;if(trigger==='manual'){return;}evnt.stopPropagation();const rowid=getRowid($xeTable,row);if(!lazy||!rowExpandLazyLoadedMaps[rowid]){const expanded=!$xeTable.isRowExpandByRow(row);const columnIndex=expandColumn?$xeTable.getColumnIndex(expandColumn):-1;const $columnIndex=expandColumn?$xeTable.getVMColumnIndex(expandColumn):-1;$xeTable.setRowExpand(row,expanded);dispatchEvent('toggle-row-expand',{expanded,column:expandColumn,columnIndex,$columnIndex,row,rowIndex:$xeTable.getRowIndex(row),$rowIndex:$xeTable.getVMRowIndex(row)},evnt);}},/**
|
|
20272
20273
|
* 行分组事件
|