在R Shiny中调用downloadHandler函数时,可以通过使用modalDialog函数生成一个弹出窗口,并在其中显示一个选择框,提示用户选择要下载的对象。
以下是一个示例代码:
library(shiny)
ui <- fluidPage(
actionButton("downloadBtn", "Download"),
tags$script(
HTML(
"
$(document).on('click', '#downloadBtn', function() {
var modal = $('<div>').attr('id', 'downloadModal').addClass('modal fade');
var modalDialog = $('<div>').addClass('modal-dialog');
var modalContent = $('<div>').addClass('modal-content');
var modalHeader = $('<div>').addClass('modal-header').html('<h4 class=\"modal-title\">Select Object to Download</h4>');
var modalBody = $('<div>').addClass('modal-body');
var selectInput = $('<select>').attr('id', 'downloadSelect').addClass('form-control');
var option1 = $('<option>').attr('value', 'object1').text('Object 1');
var option2 = $('<option>').attr('value', 'object2').text('Object 2');
var modalFooter = $('<div>').addClass('modal-footer');
var downloadBtn = $('<button>').attr('id', 'confirmDownload').addClass('btn btn-primary').text('Download');
modalBody.append(selectInput.append(option1).append(option2));
modalFooter.append(downloadBtn);
modalContent.append(modalHeader).append(modalBody).append(modalFooter);
modalDialog.append(modalContent);
modal.append(modalDialog);
Shiny.onInputChange('showModal', true);
$(document.body).append(modal);
$('#downloadModal').modal('show');
});
$(document).on('click', '#confirmDownload', function() {
var selectedObject = $('#downloadSelect').val();
Shiny.onInputChange('selectedObject', selectedObject);
$('#downloadModal').modal('hide');
});
Shiny.addCustomMessageHandler('closeModal', function(message) {
$('#downloadModal').modal('hide');
});
"
)
)
)
server <- function(input, output, session) {
observeEvent(input$selectedObject, {
# 根据选择的对象进行相应的下载操作
if (input$selectedObject == "object1") {
# 下载对象1
} else if (input$selectedObject == "object2") {
# 下载对象2
}
# 下载完成后关闭弹出窗口
session$sendCustomMessage("closeModal", "")
})
}
shinyApp(ui, server)
在上述代码中,我们使用了JavaScript代码来生成一个弹出窗口,并在其中显示一个选择框。用户可以选择要下载的对象,然后点击"Download"按钮进行下载。选择的对象会通过Shiny的input变量传递到服务器端,服务器端可以根据选择的对象进行相应的下载操作。下载完成后,通过发送自定义消息的方式关闭弹出窗口。
请注意,上述代码中使用了Shiny的JavaScript API和自定义消息处理器来实现弹出窗口和与服务器端的通信。这里没有提及腾讯云相关产品和产品介绍链接地址,因为这个问题与云计算品牌商无关。
领取专属 10元无门槛券
手把手带您无忧上云