我正在尝试根据此代码块分别用绿色和红色为DT::Datatable
的某个列(第三列)的正值和负值着色,但是我不是JavaScript用户。有什么办法设置吗?
library(DT)
datatable(head(iris)) %>%
formatStyle(1:4, color = JS("value % 1 === 0 ? 'red' : ''"))
答案 0 :(得分:2)
您可以使用DT::styleInterval
:
library(DT)
## data (iris dataset contains no negative values)
dat <- data.frame(
letters = LETTERS[1:26],
numbers = sample(c(-1, -0.5, 0, 0.5, 1), 26, replace = TRUE)
)
datatable(dat) %>%
formatStyle(
columns = "numbers",
color = styleInterval(cuts = 0, values = c("red", "green")),
fontWeight = "bold"
)
注意:如果应忽略零值,则可以将黑色设置为零附近的小区域:
eps <- 1E-5
datatable(dat) %>%
formatStyle(
columns = "numbers",
color = styleInterval(cuts = c(-eps, eps), values = c("red", "black", "green")),
fontWeight = "bold"
)