- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
目前还没有发布好的、完整的指南来帮助用户加快如何使用最新的 UploadSet 控件实现挂起的附件。
最佳答案
***欢迎改进。
这是待上传的完整实现,具有以下附加功能:
提示:避免使用名为 UploadCollection
的其他控件,该控件存在太多错误,并且在尝试找出替代方案时浪费了太多时间。 UploadSet
是您无缺陷、 Shiny 、最好的 friend 。
外观:*复选框的对齐和控件视觉效果的修改是通过自定义 CSS 完成的(本答案中引用)
先决条件:
sap/m/MessageBox
作为MessageBox
和sap/m/MessageToast
作为MessageToast
UploadSet
的命名空间:xmlns:up="sap.m.upload"
that
的函数中定义 var that
= this
查看:
<up:UploadSet id="attachmentUpl" instantUpload="false" maxFileSize="2" noDataDescription="" noDataText="" selectionChanged="onSelectionChangeAttachment"
uploadCompleted="onUploadCompleted" uploadUrl="/sap/opu/odata/sap/Z9NRS_CONFIG_SRV/Z9NRS_REQ_ATTACHSet" visible="true">
<up:toolbar>
<OverflowToolbar>
<CheckBox id="checkbox" select="onSelectAllAttachments" visible="false" />
<ToolbarSpacer/>
<Button id="upload" enabled="true" text="Upload" press="onStartUpload" type="Transparent" visible="true" />
<Button id="remove" enabled="false" icon="sap-icon://delete" press="onRemove" type="Transparent" visible="true" />
<Button id="download" enabled="false" icon="sap-icon://download" press="onDownload" type="Transparent" visible="true" />
</OverflowToolbar>
</up:toolbar>
</up:UploadSet>
Controller :
在onInit
内:
var oAttachmentUpl= this.byId('attachmentUpl').getDefaultFileUploader();
oAttachmentUpl.setIcon("sap-icon://add").setIconOnly(true);
oAttachmentUpl.setMultiple(true); //lets user select more than 1file at a time in their FileExplorer
加载附件:
loadAttachments:function(){
var sPath= "/Z9NRS_REQ_ATTACHSet?$filter=(ZNRS_REQUEST eq '"+sRequestId+"')";
var oAttachmentUpl= this.byId("attachmentUpl");
oAttachmentUpl.getList().setMode("MultiSelect");
this.getView().getModel().read(sPath,{
success:function(oData){
var oAttachmentsModel= new JSONModel(oData);
oAttachmentUpl.setModel(oAttachmentsModel).bindAggregation("items", "/results", new sap.m.upload.UploadSetItem({
fileName: "{FILE_NAME}", mediaType: "{MIME_TYPE}", visibleEdit:false, visibleRemove:false,
url: "/sap/opu/odata/sap/Z9NRS_CONFIG_SRV/Z9NRS_REQ_ATTACHSet(ZNRS_REQUEST='" + "{OBJECT_ID}" + "',FILE_NAME='" + "{FILE_NAME}" + "')/$value"
}));
if(oAttachmentUpl.getItems().length>0){
that.byId('checkbox').setVisible(true);
}
},
error:function(oError){that.parseErrorMsg()}
});
}
其他一切:
onSelectAllAttachments: function(oEvent) {
var aUploadedItems = this.byId("attachmentUpl").getItems(),
bSelected = oEvent.getSource().getSelected();
if (bSelected) { //if CheckBox is selected
aUploadedItems.forEach(oItem => oItem.getListItem().setSelected(true));
this.byId('download').setEnabled(true);
} else {
aUploadedItems.forEach(oItem => oItem.getListItem().setSelected(false));
this.byId('remove').setEnabled(false);
this.byId('download').setEnabled(false);
}
},
onSelectionChangeAttachment: function() {
if (this.byId("attachmentUpl").getList().getSelectedItems().length > 0) { //if user selects 1 or more uploaded item
this.byId("remove").setEnabled(true);
this.byId("download").setEnabled(true);
} else {
this.byId("remove").setEnabled(false);
this.byId("download").setEnabled(false);
}
},
onRemove: function(oEvent) {
var oAttachmentUpl = this.byId("attachmentUpl");
oAttachmentUpl.setBusy(true);
oAttachmentUpl.getItems().forEach(oItem => {
if (oItem.getListItem().getSelected()) {
var sPath = oItem.getProperty("url").split("SRV")[1]; //eg /Z9NRS_REQ_ATTACHSet
this.getView().getModel().remove(sPath, {
success: function() {
oAttachmentUpl.removeItem(oItem); //remove from displayed list
},
error: function(oError) {
that.parseErrorMsg();
}
});
}
});
oEvent.getSource().setEnabled(false);
this.byId("download").setEnabled(false);
if (oAttachmentUpl.getItems().length > 0) {
this.byId('checkbox').setVisible(true);
} else {
this.byId('checkbox').setVisible(false);
}
oAttachmentUpl.setBusy(false);
},
onDownload: function(oEvent) {
var oAttachmentUpl = this.byId("attachmentUpl");
oAttachmentUpl.setBusy(true);
oAttachmentUpl.getItems().forEach(oItem => {
if (oItem.getListItem().getSelected()) {
oItem.download(true);
oItem.getListItem().setSelected(false);
}
});
oAttachmentUpl.setBusy(false);
oEvent.getSource().setEnabled(false);
},
onStartUpload: function() {
var oAttachmentUpl = this.byId("attachmentUpl");
var aIncompleteItems = oAttachmentUpl.getIncompleteItems();
this.iIncompleteItems = aIncompleteItems.length; //used to turn off busy indicator upon completion of all pending uploads
if (this.iIncompleteItems !== 0) {
oAttachmentUpl.setBusy(true);
this.i = 0; //used to turn off busy indicator when all uploads complete
for (var i = 0; i < this.iIncompleteItems; i++) {
var sFileName = aIncompleteItems[i].getProperty("fileName");
var oXCSRFToken = new sap.ui.core.Item({
key: "X-CSRF-Token",
text: this.getOwnerComponent().getModel().getSecurityToken()
});
var oSlug = new sap.ui.core.Item({
key: "SLUG",
text: this.sRequestId + "/" + sFileName
});
oAttachmentUpl.addHeaderField(oXCSRFToken).addHeaderField(oSlug).uploadItem(aIncompleteItems[i]);
oAttachmentUpl.removeAllHeaderFields(); //at least slug header field must be reset after each upload
}
}
},
onUploadCompleted: function() {
this.i += 1;
if (this.i === this.iIncompleteItems) { //turn off busy indicator when all attachments have completed uploading
this.byId('attachmentUpl').setBusy(false);
}
},
parseErrorMsg: function(oError) { //parses oData error messages dependent on different return values
var oMessage, sType;
if (oError.response) { //for update
sType = typeof oError.response;
if (sType === "string" || sType === "object") oMessage = JSON.parse(oError.response.body).error.message.value;
else return MessageBox.error("Unhandled server error:\n\n" + oError.response + "\n\nReport this issue to Admin for a future fix.");
} else if (oError.responseText) { //for create
sType = typeof oError.responseText;
if (sType === "string" || sType === "object") oMessage = JSON.parse(oError.responseText).error.message.value;
else return MessageBox.error("Unhandled server error:\n\n" + oError.responseText + "\n\nReport this issue to Admin for a future fix.");
} else if (!oError) return MessageToast.show("Error message is undefined");
MessageBox.error(oMessage);
}
/*uploadSet: align toolbar checkbox with ListItems' checkboxes*/
.sapMIBar.sapMTB.sapMTBNewFlex.sapMTBInactive.sapMTBStandard.sapMTB-Transparent-CTX {
padding-left: 2px;
}
/*uploadSet: reduce height of each uploadItem*/
.sapMLIB.sapMLIB-CTX.sapMLIBShowSeparator.sapMLIBTypeInactive.sapMLIBFocusable.sapMCLI.sapMUCItem {
padding-top: 10px;
padding-bottom: 5px;
}
/*uploadSet: align uploadItem checkboxes to center*/
.sapMCb.sapMLIBSelectM {
align-self: center !important;
}
/*uploadSet: remove rename icon from pending files*/
.sapMBtnBase.sapMBtn.sapMUCEditBtn.sapMUCFirstButton {
display: none;
}
/*uploadSet: remove pending bar and text*/
.sapMFlexBox.sapMVBox.sapMFlexBoxJustifyStart.sapMFlexBoxAlignItemsStretch.sapMFlexBoxWrapNoWrap.sapMFlexBoxAlignContentStretch.sapMFlexBoxBGTransparent.sapMUSProgressBox {
display: none;
}
/*uploadSet: center the x button for pending files*/
.sapMUCButtonContainer {
align-self: center;
}
只需按上传
按钮(位于UploadSet工具栏中)即可上传所有待处理的附件。
为了让您的实现正常运行,需要自定义所有项目:
sPath
用于 loadAttachments
函数中的 oData 调用以及 UploadSetItem 中的几乎所有参数UploadSet
控件的uploadUrl
属性sPath
用于 onRemove
函数中的 oData 调用onStartUpload
函数中的 SLUG header text
值不包括的功能:
关于sapui5 - 如何使用Uploadset实现待处理附件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64672848/
我没有上传附件以使浏览器正常工作。 一些提示是 here , 其他 there . The docs非常好,但我无法将其转换为 AJAX 上传。 我正在寻找一个 super 简单的 HTML/Java
我有一个应用程序可以收集一些信息并允许用户使用 Android 的 Intent 框架共享这些信息。 到目前为止,它以纯文本形式共享报告:使用 putExtra(Intent.EXTRA_TEXT,
我正在尝试通过我的应用程序发布带有附件图片的消息,所以我使用了以下代码: function yamPost(mytoken) { var msg_Body = jQuery("#myB
我在用户表中使用了多对多关系来使登录用户关注另一个用户,但我自己没有弄清楚,我检查了其他人做了什么,并尝试做类似的事情,并且它有效。在我的方法中,我有: function follow(User $u
我正在用 PHP 创建脚本,其作用是将 IMAP 服务器备份到 MySQL 数据库。 我现在的问题是: 如果电子邮件有附件,附件是嵌入在电子邮件本身中还是服务器上的一个单独文件? 我问的原因是: 我可
我正在使用 RavenDB,在我处理任何附件之前删除了一些带有附件的测试文档,所以我在想它们是否还在磁盘上的某个地方,以及如何轻松地找到它们?。 另一个问题是:当文档被删除时,它有一个附件,附件会被自
当您使用 ACTION_SEND Intent (使用额外的 EXTRA_STREAM)将文件附加到电子邮件时,电子邮件应用程序是否将该附加文件复制到它自己的位置?我的应用程序创建了一个文件并将其附加
所以: // Setup mail class, recipients and body $mailer->AddAttachment('/home/mywebsite/public_html/fil
您好,我需要一个 DnD 解决方案来将 Outlook 邮件附件拖到 Stackpane。 JavaFX/展望 2010 stackpaneDragAndDropZone.setOnDragO
我尝试制作一个 PhpSpreadsheet 文档,然后将他添加到邮件附件中。也许是太热了,但在 phpSpreadsheet 文档中几个小时后,我还没有找到任何东西。 这是我发送邮件的文件 $nam
有什么方法可以动画删除 UITableView 单元格附件吗? 我当前正在显示一个 UITableViewCellAccessoryDisclosureIndicator,但我想在所有可见表格单元格上
我正在编写一个 iPhone 应用程序,它要求我以编程方式发送电子邮件附件。附件是我通过代码创建的 csv 文件。然后,我将文件附加到电子邮件中,附件就会显示在手机上。但是,当我向自己发送电子邮件时,
我正在尝试通过收件箱中的名称“MacroEnabled”访问子文件夹,找到其中的所有附件并将它们保存到本地驱动器。 我使用此代码创建一个名为“Documents”的文件夹并保存附件。然而,在进行第二次
将 corda 升级到版本 4 后,我收到 net.corda.core.transactions.MissingContractAttachments:找不到 com.template.contra
我正在尝试让 Jenkins 将一个或一组文件附加到作业已完成的电子邮件通知中。我不断收到以下错误: 发送电子邮件以触发:成功错误:访问要附加的文件时出错:需要 Ant GLOB 模式,但看到 C:\
我创建了一个由来自 mysql 的数据填充的 UITableView(使用 NSJSONSERIALIZATION)。现在问题是一回事。我检索到的是产品名称。我想要一个附件 View (像单元格右侧的
我开发了一个 Java 客户端应用程序,用于下载我自己的电子邮件。我发现我无法在电子邮件中找到某些附件,特别是当我向经过认证的公司发送电子邮件时收到的作为收据的 XML 文件。我用于下载附件的代码:
我正在将我的 sqlite 数据库转换为 Couchdb。我可以转换数据库并上传到 Couchdb 服务器。除了图像之外的一切。我想将图像作为独立附件上传,我想使用 javascript、REST 和
我编写了一段代码,以便能够启动默认的电子邮件服务提供商,即我的 Outlook。这是我的代码: if(role.getValue().equals("1")) { Desktop desktop =
我正在尝试使用链接上共享的代码使用 python 从 Gmail 下载电子邮件附件 https://gist.github.com/baali/2633554 我想应用时间过滤器+主题过滤器并下载附件
我是一名优秀的程序员,十分优秀!