Как выровнять заголовки столбцов с данными по левому краю в Shiny?
По какой-то причине у меня не может быть заголовков столбцов таблицы данных, правильно выровненных по левому краю:
library(shiny)
library(DT)
library(ggplot2)
ui <- fluidPage(
title = "Examples of DataTables",
sidebarLayout(mainPanel =
mainPanel(
tabsetPanel(
id = 'dataset',
tabPanel("diamonds", DT::dataTableOutput("mytable1"))
)
),sidebarPanel = sidebarPanel()
)
)
server <- function(input, output) {
# choose columns to display
diamonds2 = ggplot2::diamonds[sample(nrow(ggplot2::diamonds), 1000), ]
output$mytable1 <- DT::renderDataTable({
DT::datatable(diamonds2,
extensions = c('Buttons',
#'Autofill',
'ColReorder',
'Responsive',
'Scroller'),
style = 'bootstrap',
class = 'table-bordered stripe table-condensed',
filter = list(position = 'top', clear = FALSE),
rownames = FALSE,
options = list( dom = 'Bfrtip',
buttons = list(list(extend = 'csv',
buttons = c('csv'),
exportOptions = list(modifiers = list(page = "current"))
)
),
search = list(regex = TRUE, caseInsensitive = FALSE),
#autofill = TRUE,
colReorder = TRUE,
deferRender = TRUE,
scrollY = 200,
scroller = TRUE,
columnDefs = list(list(className = 'dt-left', targets = '_all'))
)
)
})
}
shinyApp(ui, server)
2 ответа
Решение
Это должно сделать это.
С #mytable1 .table th
мы можем получить доступ к заголовку таблицы.
С #mytable1 .table td
мы можем получить доступ к ячейкам таблицы.
С text-align: left;
выравниваем текст по левому краю.
library(shiny)
library(shinyjs)
library(DT)
library(ggplot2)
ui <- fluidPage(
title = "Examples of DataTables",
## CSS-Code ###############
inlineCSS("
#mytable1 .table th {
text-align: left;
}
#mytable1 .table td {
text-align: left;
}
"
),
#####################
sidebarLayout(mainPanel =
mainPanel(
tabsetPanel(
id = 'dataset',
tabPanel("diamonds", DT::dataTableOutput("mytable1"))
)
),sidebarPanel = sidebarPanel()
)
)
server <- function(input, output) {
# choose columns to display
diamonds2 = ggplot2::diamonds[sample(nrow(ggplot2::diamonds), 1000), ]
output$mytable1 <- DT::renderDataTable({
DT::datatable(diamonds2,
extensions = c('Buttons',
#'Autofill',
'ColReorder',
'Responsive',
'Scroller'),
style = 'bootstrap',
class = 'table-bordered stripe table-condensed',
filter = list(position = 'top', clear = FALSE),
rownames = FALSE,
options = list( dom = 'Bfrtip',
buttons = list(list(extend = 'csv',
buttons = c('csv'),
exportOptions = list(modifiers = list(page = "current"))
)
),
search = list(regex = TRUE, caseInsensitive = FALSE),
#autofill = TRUE,
colReorder = TRUE,
deferRender = TRUE,
scrollY = 200,
scroller = TRUE,
columnDefs = list(list(className = 'dt-left', targets = '_all'))
)
)
})
}
shinyApp(ui, server)
Это сработало для меня:
columnDefs = list(list(className = 'dt-head-center', targets = '_all'))