1

皆さん、元のflot.jsライブラリ内でこのエラーが発生しました。スクリプトのこの部分の何が問題なのだろうか? *エラーは Firefox の Fire バグです。エラー メッセージは次のとおりです。

ReferenceError: $ is not defined

$(document).ready(function () { 

エラーコードであるという主張を開始する行は次のとおりです。

$(document).ready(function () {
$.plot($("#flot-placeholder1"), dataset, options);
$("#flot-placeholder1").UseTooltip();
}); 

以下は、エラー行の前の内容です。

 <script>
//******* 2012 Gold Price Chart
var data1 = [
[gd(2012, 0, 1), 1652.21], [gd(2012, 1, 1), 1742.14], [gd(2012, 2, 1), 1673.77], [gd(2012, 3, 1), 1649.69],
[gd(2012, 4, 1), 1591.19], [gd(2012, 5, 1), 1598.76], [gd(2012, 6, 1), 1589.90], [gd(2012, 7, 1), 1630.31],
[gd(2012, 8, 1), 1744.81], [gd(2012, 9, 1), 1746.58], [gd(2012, 10, 1), 1721.64], [gd(2012, 11, 2), 1684.76]
];
var data2 = [
[gd(2012, 0, 1), 0.63], [gd(2012, 1, 1), 5.44], [gd(2012, 2, 1), -3.92], [gd(2012, 3, 1), -1.44],
[gd(2012, 4, 1), -3.55], [gd(2012, 5, 1), 0.48], [gd(2012, 6, 1), -0.55], [gd(2012, 7, 1), 2.54],
[gd(2012, 8, 1), 7.02], [gd(2012, 9, 1), 0.10], [gd(2012, 10, 1), -1.43], [gd(2012, 11, 2), -2.14]
];
var dataset = [
{ label: "Gold Price", data: data1, points: { symbol: "triangle"} },
{ label: "Change", data: data2, yaxis: 2 }
];
var options = {
series: {
lines: {
show: true
},
points: {
radius: 3,
fill: true,
show: true
}
},
xaxis: {
mode: "time",
tickSize: [1, "month"],
tickLength: 0,
axisLabel: "2012",
axisLabelUseCanvas: true,
axisLabelFontSizePixels: 12,
axisLabelFontFamily: 'Verdana, Arial',
axisLabelPadding: 10
},
yaxes: [{
axisLabel: "Gold Price(USD)",
axisLabelUseCanvas: true,
axisLabelFontSizePixels: 12,
axisLabelFontFamily: 'Verdana, Arial',
axisLabelPadding: 3,
tickFormatter: function (v, axis) {
return $.formatNumber(v, { format: "#,###", locale: "us" });
}
}, {
position: "right",
axisLabel: "Change(%)",
axisLabelUseCanvas: true,
axisLabelFontSizePixels: 12,
axisLabelFontFamily: 'Verdana, Arial',
axisLabelPadding: 3
}
],
legend: {
noColumns: 0,
labelBoxBorderColor: "#000000",
position: "nw"
},
grid: {
hoverable: true,
borderWidth: 2,
borderColor: "#633200",
backgroundColor: { colors: ["#ffffff", "#EDF5FF"] }
},
colors: ["#FF0000", "#0022FF"]
};

=================更新============================== ===================== 皆さんこんにちは。答えてくれてありがとう!スクリプトをロードする順序は次のとおりです (DW CS4 でテストしているため、正しくロードします 1. jquery-1.8.3.min.js 2. jquery.flot.min.js" 3. jquery.flot.time.js" 4. jquery.flot.symbol.js 5. jquery.flot.axislabels.js 6. jshashtable-2.1.js 7. jquery.numberformatter-1.2.3.min.js

したがって、順序は問題ではないと考えています。チュートリアルに従うと、ここで行うように指示されました 。 -chart.html

また、これらのコードが Firefox/firebug によって停止されていることもわかりました。ストップはコードの 2 行目の前に置かれました --> '$(this).bind("plot...'.

$.fn.UseTooltip = function () {
$(this).bind("plothover", function (event, pos, item) {
if (item) {
if ((previousLabel != item.series.label) || (previousPoint != item.dataIndex)) {
previousPoint = item.dataIndex;
previousLabel = item.series.label;
$("#tooltip").remove();
var x = item.datapoint[0];
var y = item.datapoint[1];
var color = item.series.color;
var month = new Date(x).getMonth();
//console.log(item);
if (item.seriesIndex == 0) {
showTooltip(item.pageX,
item.pageY,
color,
"<strong>" + item.series.label + "</strong><br>" + monthNames[month] + " : <strong>" + y + "</strong>(USD)");
} else {
showTooltip(item.pageX,
item.pageY,
color,
"<strong>" + item.series.label + "</strong><br>" + monthNames[month] + " : <strong>" + y + "</strong>(%)");
}
}
} else {
$("#tooltip").remove();
previousPoint = null;
}
});
}; 

ありがとう。

ケビンへのさらなる質問は、彼の答えについてコメントの下で尋ねられます....

4

2 に答える 2

3

エラーは次のとおりです。

$(document)

$定義されていません。これは、jQuery を含めていないか、含めるのが遅すぎるか、$.noConflict()間違って使用していることを意味します。

より具体的には$ === undefined、 および undefined は関数ではないため、実行できません。

于 2013-04-18T18:57:23.483 に答える
3

つまり、HTML ページに jQuery を含める必要があります。$(document).ready行を実行する前に、これ (または jQuery ライブラリへの別の参照) を追加します。

<script type="text/javascript" src="//code.jquery.com/jquery-1.9.1.min.js"></script>

$は、使用する前に利用可能にする必要がある jQuery ライブラリを指します。

さらに、jQuery ライブラリをロードした後、flot ライブラリをロードする必要があります。flot は jQuery プラグインなので、jQuery ライブラリに依存します。

于 2013-04-18T18:57:28.473 に答える