3

そのため、ハイチャートの使用に問題があります。最近、Internet Explorer 8 でのみ発生するエラーが発生しました。失敗した行は、highcharts.src.js ファイルの行 270 から発生します。

function css (el, styles) {
  if (isIE) {
    if (styles && styles.opacity !== UNDEFINED) {
      styles.filter = 'alpha(opacity='+ (styles.opacity * 100) +')';
    }
  } 

  extend(el.style, styles); // This line fails...
}

チャートを作成するコードは次のとおりです。

$(document).ready(function() {
  chartcontainer1700 = new Highcharts.Chart({
    chart: {
      renderTo: 'container1700'
    },
    title: {
      text: 'Loading chart...'
    }
  });
});

function onSuccess(options){
  if (options.hasOwnProperty('restErrorMessage') && options.restErrorMessage != null) {
     alert(options.restErrorMessage);
  }
  chartcontainer1700.destroy();
  chartcontainer1700 = new Highcharts.Chart(options);
  chartcontainer1700.redraw();
};

onSuccess関数は、次のように、Json であるチャート データを提供するために Web サービス呼び出しが成功した後に起動されます。

{"chart": {
  "renderTo":"container0438",
  "zoomType":"xy"},
  "credits": { 
    "enabled": false,
    "position": {
      "align":"right",
      "x":-10,
      "verticalAlign":"bottom",
      "y":-5
  },
  "href":"http:\/\/www.website.com",
  "text":"Chart"
},
"legend": {
  "borderRadius":0,
  "borderWidth":0,
  "enabled":true
},
"series":[{"data":[67.5,67.75],"name":"ME","type":"spline","yAxis":0}],
"title":{"align":"center","text":""},
"xAxis":[{
  "categories":["Mar 22, 2011 - Mar 26, 2011","Mar 27, 2011 - Mar 29, 2011"],
  "maxPadding":5,"minPadding":1
 }],
 "yAxis":[{
   "labels":{
     "style":{"color":"Gray"}
   },
   "opposite":false,
   "title":{"text":"ME %","style":{"color":"Gray"}},
   "type":"spline"}],
   "exporting":{"enabled":true}
}

他のブラウザではすべてが完璧に機能します。何か考えはありますか?

ありがとう!

4

1 に答える 1

0

ハイチャートをいじって、このエラーメッセージを見たことを思い出しましたが、クロムでテストしていました. サービスから返されるデータではないことを確認するためだけに、ハイチャートにフィードされるjsonデータをハードコードするだけで非常に役立つことがわかりました。また、destroy を呼び出す必要がなく、グラフを再描画する方法を見つけることも試してみます。チャートを破棄することが提案されていることは知っていますが、私にとっては時々問題がありました。おそらく、チャートの同じインスタンス chartcontainer1700 を再利用し、渡されるデータを変更して再描画するだけです。

于 2012-02-21T01:57:10.990 に答える