我使用JSON对象提供的数据在画布上绘制线条:
var data = { values:[
{ X: "04-28", Xt: "7:45 pm", Ys: 116, Yd: 74, Yp: 0},
{ X: "04-29", Xt: "2:00 am", Ys: 112, Yd: 73, Yp: 0},
//
使用一些jQuery绘制线条:
c.lineWidth = 4;
c.strokeStyle = '#f00';
c.beginPath();
c.moveTo(getXPixel(0), getYPixel(data.values[0].Ys));
for(var i = 1; i < data.values.length; i ++) {
c.lineTo(getXPixel(i), getYPixel(data.values[i].Ys));
}
c.stroke();
要绘制多行(以处理'Yd'和'Yp'以及稍后可能需要的任何其他行)我想将该位移动到一个函数中,我可以使用它来调用:< / p>
drawLine(4, '#f00', 'Ys');
我尝试过的功能:
function drawLine(width, style, d) {
c.lineWidth = width;
c.strokeStyle = style;
c.beginPath();
c.moveTo(getXPixel(0), getYPixel(data.values[0].d));
for(var i = 1; i < data.values.length; i ++) {
c.lineTo(getXPixel(i), getYPixel(data.values[i].d));
}
c.stroke();
}
不起作用。没有错误,但没有画线。如果我将'Ys'直接放在函数中,它确实有效。我如何将该位作为参数传递?
答案 0 :(得分:2)
您不希望d
的{{1}}属性,您想要values[i]
所拥有的字符串值的属性。您需要使用d
,而不是obj[d]
,如:
obj.d
例如:
function drawLine(width, style, d) {
c.lineWidth = width;
c.strokeStyle = style;
c.beginPath();
c.moveTo(getXPixel(0), getYPixel(data.values[0][d]));
for(var i = 1; i < data.values.length; i ++) {
c.lineTo(getXPixel(i), getYPixel(data.values[i][d]));
}
c.stroke();
}