2016-11-18 1 views
2

Я новичок в кодировании, и мне сложно создать один раскрывающийся список, который будет загружать одновременно два высокочастотных диаграммы.Как я могу обновить два highcharts с одним выпадающим меню?

Я попытался изменить имена параметров во избежание дублирования и объединить оба события изменения списка, поэтому оба изменения выполняются в одной функции.

[Here is my jsfiddle][1] 


<http://jsfiddle.net/hirschle/unwb4wvg/1/> 

<script src="http://code.highcharts.com/highcharts.js"></script> 
<script src="http://code.highcharts.com/modules/exporting.js"></script> 


<select id="list" name="list" multiple="multiple"> 
    <option value="A">Gender</option> 
    <option value="B">Race</option> 
    <option value="C">Earnings</option> 
</select> 

<div> 
    <div id="container" class="container" style="height: 600px"></div> 
    <div id="container2" class="container" style="height: 600px"></div> 
</div> 

Не могли бы вы взглянуть на мою скрипку и сделать обновления или предложить решение. Спасибо огромное!

[1]: http://jsfiddle.net/hirschle/unwb4wvg/1/ 
+0

В качестве подсказки: Используя функцию .val() на множественного выбора списка возвращает массив выбранных значений не строка –

ответ

0

Вот решение: jsfiddle

var chart=new Highcharts.Chart(options); 
$('#container').append(chart); 
var chart1=new Highcharts.Chart(options1); 
$('#container2').append(chart1); 

Кроме того, фрагмент показывает результат.

$(function() { 
 
     var options = { 
 
     chart: { 
 
      renderTo: 'container', 
 
      defaultSeriesType: 'column', 
 
      type: 'column', 
 
      margin: 75, 
 
      options3d: { 
 
      enabled: false, 
 
      alpha: 8, 
 
      beta: 7, 
 
      depth: 2000 
 

 
      } 
 
     }, 
 
     plotOptions: { 
 
      area: { 
 
      stacking: 'normal', 
 
      marker: { 
 
       symbol: 'circle', 
 
       radius: 1, 
 
       states: { 
 
       hover: { 
 
        enabled: true 
 
       } 
 
       } 
 
      } 
 
      } 
 
     }, 
 

 
     legend: { 
 
      layout: 'vertical', 
 
      align: 'right', 
 
      verticalAlign: 'top', 
 
      x: 10, 
 
      y: 50, 
 
      floating: false, 
 
      borderWidth: 1, 
 
      backgroundColor: ((Highcharts.theme && Highcharts.theme.legendBackgroundColor) || '#FFFFFF'), 
 
      shadow: true 
 
     }, 
 
     title: { 
 
      text: 'Average Age at Death by Gender, Race, and Birth Cohort' 
 
     }, 
 
     xAxis: { 
 
      categories: ['1980-89', '1990-99', '2000-09', '2010-19', '2020-29', '2030-2039'], 
 
      labels: { 
 
      rotation: -45, 
 
      style: { 
 
       fontSize: '15px', 
 
       fontFamily: 'Verdana, sans-serif' 
 
      } 
 
      } 
 
     }, 
 

 

 
     yAxis: { 
 
      title: { 
 
      text: 'Average Age at Death', 
 
      fontSize: '15px', 
 

 
      }, 
 
      labels: { 
 
      style: { 
 
       fontSize: '15px' 
 
      } 
 
      } 
 
     }, 
 

 
     series: [] 
 
     } 
 

 
     var options1 = { 
 
     chart: { 
 
      renderTo: 'container2', 
 
      defaultSeriesType: 'column', 
 
      type: 'column', 
 
      margin: 75, 
 
      options3d: { 
 
      enabled: false, 
 
      alpha: 8, 
 
      beta: 7, 
 
      depth: 2000 
 

 
      } 
 
     }, 
 
     plotOptions: { 
 
      area: { 
 
      stacking: 'normal', 
 
      marker: { 
 
       symbol: 'circle', 
 
       radius: 1, 
 
       states: { 
 
       hover: { 
 
        enabled: true 
 
       } 
 
       } 
 
      } 
 
      } 
 
     }, 
 

 
     legend: { 
 
      layout: 'vertical', 
 
      align: 'right', 
 
      verticalAlign: 'top', 
 
      x: 10, 
 
      y: 50, 
 
      floating: false, 
 
      borderWidth: 1, 
 
      backgroundColor: ((Highcharts.theme && Highcharts.theme.legendBackgroundColor) || '#FFFFFF'), 
 
      shadow: true 
 
     }, 
 
     title: { 
 
      text: 'Average Age at Death by Gender, Race, and Birth Cohort' 
 
     }, 
 
     xAxis: { 
 
      categories: ['1980-89', '1990-99', '2000-09', '2010-19', '2020-29', '2030-2039'], 
 
      labels: { 
 
      rotation: -45, 
 
      style: { 
 
       fontSize: '15px', 
 
       fontFamily: 'Verdana, sans-serif' 
 
      } 
 
      } 
 
     }, 
 

 

 
     yAxis: { 
 
      title: { 
 
      text: 'Average Age at Death', 
 
      fontSize: '15px', 
 

 
      }, 
 
      labels: { 
 
      style: { 
 
       fontSize: '15px' 
 
      } 
 
      } 
 
     }, 
 

 
     series: [] 
 
     } 
 

 
     $("#list").on('change', function() { 
 
     var selVal = $("#list").val(); 
 
     if (selVal == "A") { 
 
      options.series = [{ 
 
      name: 'Male', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 

 
      options1.series = [{ 
 

 
      name: 'Female', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 

 
     } else if (selVal == "B") { 
 
      options.series = [{ 
 
      name: 'White', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Black', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Hispanic', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Asian', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Other', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 
      options1.series = [{ 
 
      name: 'White', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Black', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Hispanic', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Asian', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Other', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 
     } else if (selVal == "C") { 
 
      options.series = [{ 
 
      name: 'Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 
      options1.series = [{ 
 

 
      name: 'Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 
     } else if (selVal == "A,B") { 
 
      options.series = [{ 
 

 
      name: 'White Male', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Black Male', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Hispanic Male', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Asian Male', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Other Male', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 

 
      options1.series = [{ 
 
      name: 'White Female', 
 
      data: [0,0,2,2,100,120], 
 

 
      }, { 
 
      name: 'Black Female', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Hispanic Female', 
 
      data: [5,6,7,8,9,10], 
 

 

 
      }, { 
 
      name: 'Asian Female', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Other Female', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 
     } else if (selVal == "A,C") { 
 
      options.series = [{ 
 

 
      name: 'Male Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Male Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 

 
      options1.series = [{ 
 
      name: 'Female Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 

 
      }, { 
 
      name: 'Female Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 

 
     } else if (selVal == "B,C") { 
 
      options.series = [{ 
 
      name: 'White, Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Black Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Hispanic Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Asian Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Other Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 

 
      options1.series = [{ 
 

 
      name: 'White, Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Black Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Hispanic Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Asian Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Other Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 

 

 
     } else if (selVal == "A,B,C") { 
 
      options.series = [{ 
 

 
      name: 'White Male Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'White Male Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Black Male Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Black Male Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Hispanic Male Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Hispanic Male Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Asian Male Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Asian Male Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Other Male Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Other Male Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 
      options1.series = [{ 
 
      name: 'White Female Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'White Female Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 

 
      }, { 
 
      name: 'Black Female Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 

 
      }, { 
 
      name: 'Black Female Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Hispanic Female Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Hispanic Female Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Asian Female Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Asian Female Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Female Other Ern<Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }, { 
 
      name: 'Female Other Ern>=Med', 
 
      data: [5,6,7,8,9,10], 
 

 
      }] 
 
     } 
 
     var chart=new Highcharts.Chart(options); 
 
     $('#container').append(chart); 
 
     var chart1=new Highcharts.Chart(options1); 
 
     $('#container2').append(chart1); 
 
     }); 
 
});
.container { 
 
    display: inline-block; 
 
    height: 500px; 
 
    width: 500px; 
 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script> 
 
<script src="http://code.highcharts.com/highcharts.js"></script> 
 
<script src="http://code.highcharts.com/modules/exporting.js"></script> 
 

 

 
<select id="list" name="list" multiple="multiple"> 
 
    <option value="A">Gender</option> 
 
    <option value="B">Race</option> 
 
    <option value="C">Earnings</option> 
 
</select> 
 

 
<div> 
 
    <div id="container" class="container" style="height: 600px"></div> 
 
    <div id="container2" class="container" style="height: 600px"></div> 
 
</div>

+0

Спасибо так много, Александру-Ionut Михая ! Это имеет большой смысл. – LH93

+0

Добро пожаловать! –

 Смежные вопросы

  • Нет связанных вопросов^_^