hw_grid小部件功能在flexdashboard中不起作用

时间:2018-03-06 21:04:42

标签: shiny flexdashboard htmlwidgets r-highcharter

由于this问题,我想将6 highcharter个图表放在一行中,就像here一样。它似乎在flexdashboard

之外正常工作
data(diamonds, package = "ggplot2")
diamonds <- diamonds[-6]

map(names(diamonds), function(x){
  diamonds[[x]] %>% 
    hchart(showInLegend = FALSE) %>% 
    hc_add_theme(hc_theme_smpl()) %>% 
    hc_title(text = x) %>% 
    hc_yAxis(title = list(text = ""))
  }) %>% 
  hw_grid(rowheight = 225, ncol = 3)  %>% browsable()

请在此处找到一个简单示例,说明它是如何在flexdashboard内无效的

---
title: "test"
runtime: shiny
output:
  flexdashboard::flex_dashboard:
    orientation: rows
    vertical_layout: fill
---
```{r}
library(highcharter)
library(data.table)
library(ggplot2)
library(htmltools)
```


### trying to render with hw_grid

```{r}
sliderInput('ncol','ncol',min = 1,max=4,value = 2)
```


```{r}
renderHighchart({
  x <- hchart(data.table(a=c(1:5),b=c(1:5)), type='column', hcaes(x=a,y=b))
lst <- list(
  x,
  x,
  x,
  x
)

hw_grid(lst, rowheight = 300,ncol = input$ncol)  %>% browsable()
})
```

### hw_grid example without rendering

```{r}

x <- hchart(data.table(a=c(1:5),b=c(1:5)), type='column', hcaes(x=a,y=b))
lst <- list(
  x,
  x,
  x,
  x
)
ncol <- 4
# ncol <- input$ncol # need to have a render as this will triger the error: Operation not allowed without an active reactive context....
hw_grid(lst, rowheight = 300,ncol = ncol)  %>% browsable()
```

### rendering example

```{r}
renderHighchart({
  x <- hchart(data.table(a=c(input$ncol*1:5),b=c(.5 * input$ncol * 1:5)), type='column', hcaes(x=a,y=b))

})
```

1 个答案:

答案 0 :(得分:2)

尝试一起使用renderUIhtmlOutput

---
title: "test"
runtime: shiny
output:
  flexdashboard::flex_dashboard:
    orientation: rows
    vertical_layout: fill
---
```{r}
library(highcharter)
library(data.table)
library(ggplot2)
library(htmltools)
library(purrr)
library(shiny)
```


### trying to render with hw_grid

```{r}
sliderInput('ncol','ncol',min = 1,max=4,value = 2)
```


```{r}
output$chart1 <- renderUI({
  x <- hchart(data.table(a=c(1:5),b=c(1:5)), type='column', hcaes(x=a,y=b))
  lst <- list(x,x,x,x)
  hw_grid(lst, rowheight = 300,ncol = input$ncol)
})

htmlOutput('chart1')
```

### hw_grid example without rendering

```{r}

x <- hchart(data.table(a=c(1:5),b=c(1:5)), type='column', hcaes(x=a,y=b))
lst <- list(
  x,
  x,
  x,
  x
)
ncol <- 4
# ncol <- input$ncol # need to have a render as this will triger the error: Operation not allowed without an active reactive context....
hw_grid(lst, rowheight = 300,ncol = ncol)  %>% browsable()
```

### rendering example

```{r}
renderHighchart({
  x <- hchart(data.table(a=c(input$ncol*1:5),b=c(.5 * input$ncol * 1:5)), type='column', hcaes(x=a,y=b))

})
```

enter image description here