将 HTML 代码隐藏在数据 table 编辑中,当使用格式 table 格式化 table 时
Hide HTML code inside datatable edit when formatting the table with formattable
我同时使用 formattable
和 DT
来创建自定义 table,同时仍然能够编辑单元格值(使用 editable=T
,来自 DT
)。
问题是,如果我使用 formattable()
进行自定义 table,每当我双击一个单元格以编辑其内容时,它会显示 HTML 代码的简单值。
举个例子:
library(formattable)
library(DT)
products <- data.frame(id = 1:5,
price = c(10, 15, 12, 8, 9),
rating = c(5, 4, 4, 3, 4),
market_share = percent(c(0.1, 0.12, 0.05, 0.03, 0.14)),
revenue = accounting(c(55000, 36400, 12000, -25000, 98100)),
profit = accounting(c(25300, 11500, -8200, -46000, 65000)))
f_table <- formattable(products, list(
price = color_tile("transparent", "lightpink")))
as.datatable(f_table, editable=T)
# as.datatable is from formattable, it lets you keep the table styling
这里可以看到问题所在:
有没有简单的方法可以解决这个问题?
您可以使用 DT
和 render
选项来设置您的 CSS.
,而不是使用 formattable
library(DT)
products <- data.frame(id = 1:5,
price = c(10, 15, 12, 8, 9),
rating = c(5, 4, 4, 3, 4))
render <- c(
"function(data, type, row){",
" if(type === 'display'){",
" var s = '<span style=\"padding: 0 4px; border-radius: 4px; background-color: pink;\">' + data + '</span>';",
" return s;",
" } else {",
" return data;",
" }",
"}"
)
datatable(products, editable = "cell",
options = list(
columnDefs = list(
list(targets = 2, render = JS(render))
)
)
)
奇怪的事情发生了:如果您双击恰好单元格内容(值,例如 10),则编辑不起作用。您必须双击单元格而不是值。
编辑
这是另一个解决方案,摘自 。
library(DT)
products <- data.frame(id = 1:5,
price = c(10, 15, 12, 8, 9),
rating = c(5, 4, 4, 3, 4))
break_points <-
function(x) stats::quantile(x, probs = seq(.05, .95, .05), na.rm = TRUE)
red_shade <-
function(x) round(seq(255, 40, length.out = length(x) + 1), 0) %>%
{paste0("rgb(255,", ., ",", ., ")")}
brks <- apply(products, 2, break_points)
clrs <- apply(brks, 2, red_shade)
column <- "price"
datatable(products, editable = "cell") %>%
formatStyle(column, backgroundColor = styleInterval(brks[,column], clrs[,column]))
我同时使用 formattable
和 DT
来创建自定义 table,同时仍然能够编辑单元格值(使用 editable=T
,来自 DT
)。
问题是,如果我使用 formattable()
进行自定义 table,每当我双击一个单元格以编辑其内容时,它会显示 HTML 代码的简单值。
举个例子:
library(formattable)
library(DT)
products <- data.frame(id = 1:5,
price = c(10, 15, 12, 8, 9),
rating = c(5, 4, 4, 3, 4),
market_share = percent(c(0.1, 0.12, 0.05, 0.03, 0.14)),
revenue = accounting(c(55000, 36400, 12000, -25000, 98100)),
profit = accounting(c(25300, 11500, -8200, -46000, 65000)))
f_table <- formattable(products, list(
price = color_tile("transparent", "lightpink")))
as.datatable(f_table, editable=T)
# as.datatable is from formattable, it lets you keep the table styling
这里可以看到问题所在:
有没有简单的方法可以解决这个问题?
您可以使用 DT
和 render
选项来设置您的 CSS.
formattable
library(DT)
products <- data.frame(id = 1:5,
price = c(10, 15, 12, 8, 9),
rating = c(5, 4, 4, 3, 4))
render <- c(
"function(data, type, row){",
" if(type === 'display'){",
" var s = '<span style=\"padding: 0 4px; border-radius: 4px; background-color: pink;\">' + data + '</span>';",
" return s;",
" } else {",
" return data;",
" }",
"}"
)
datatable(products, editable = "cell",
options = list(
columnDefs = list(
list(targets = 2, render = JS(render))
)
)
)
奇怪的事情发生了:如果您双击恰好单元格内容(值,例如 10),则编辑不起作用。您必须双击单元格而不是值。
编辑
这是另一个解决方案,摘自
library(DT)
products <- data.frame(id = 1:5,
price = c(10, 15, 12, 8, 9),
rating = c(5, 4, 4, 3, 4))
break_points <-
function(x) stats::quantile(x, probs = seq(.05, .95, .05), na.rm = TRUE)
red_shade <-
function(x) round(seq(255, 40, length.out = length(x) + 1), 0) %>%
{paste0("rgb(255,", ., ",", ., ")")}
brks <- apply(products, 2, break_points)
clrs <- apply(brks, 2, red_shade)
column <- "price"
datatable(products, editable = "cell") %>%
formatStyle(column, backgroundColor = styleInterval(brks[,column], clrs[,column]))