繁体   English   中英

在ASP.NET中动态生成的画布元素

[英]Dynamically generated canvas elements in ASP.NET

我有多个基于VB代码动态显示在页面上的画布元素。

这是我的aspx页面的样子:

<canvas id="canvasnhlrc" width="225" height="200" runat="server"></canvas>
<canvas id="canvascwl" width="225" height="200" runat="server"></canvas>
<canvas id="canvashslanguages" width="225" height="200" runat="server"></canvas>

这是我的aspx.vb代码如下所示:

canvasnhlrc.Visible = False
canvascwl.Visible = False
canvashslanguages.Visible = False

        If RouteData.Values("mediasubType") IsNot Nothing Then

            Dim qsubMedia As String = RouteData.Values("mediasubType")

            Select Case qsubMedia

                Case "nhlrc"

                    canvasnhlrc.Visible = True

                Case "cwl"

                    canvascwl.Visible = True

                Case "hslanguages"

                    canvashslanguages.Visible = True

            End Select

        End If

因此,如果我的页面是example.com/nhlrc ,那么画布将生成为

<canvas id="ContentPlaceHolder2_canvasnhlrc" width="225" height="200"></canvas>

因此,我将js文件格式化如下:

function init() 
{ 
    var w1 = document.getElementById('ContentPlaceHolder2_canvasnhlrc')
    var w1x = w1.getContext('2d');
    w1x.shadowOffsetX = 0;
    w1x.shadowOffsetY = 0;
    w1x.shadowBlur = 20;
    w1x.shadowColor = "rgba(0, 0, 0, 0.75)";
    w1x.fillStyle = 'rgb(218, 233, 246)';
    w1x.beginPath();
    w1x.moveTo(25, 25);
    w1x.lineTo(175, 25);
    w1x.lineTo(175, 50);
    w1x.lineTo(200, 75);
    w1x.lineTo(175, 100);
    w1x.lineTo(175, 175);
    w1x.lineTo(25, 175);
    w1x.closePath();
    w1x.fill();

    var w2 = document.getElementById('ContentPlaceHolder2_canvascwl')
    var w2x = w2.getContext('2d');
    w2x.shadowOffsetX = 0;
    w2x.shadowOffsetY = 0;
    w2x.shadowBlur = 20;
    w2x.shadowColor = "rgba(0, 0, 0, 0.75)";
    w2x.fillStyle = 'rgb(12, 64, 114)';
    w2x.beginPath();
    w2x.moveTo(25, 25);
    w2x.lineTo(175, 25);
    w2x.lineTo(175, 50);
    w2x.lineTo(200, 75);
    w2x.lineTo(175, 100);
    w2x.lineTo(175, 175);
    w2x.lineTo(25, 175);
    w2x.closePath();
    w2x.fill();

    var w3 = document.getElementById('ContentPlaceHolder2_canvashslanguages')
    var w3x = w3.getContext('2d');
    w3x.shadowOffsetX = 0;
    w3x.shadowOffsetY = 0;
    w3x.shadowBlur = 20;
    w3x.shadowColor = "rgba(0, 0, 0, 0.75)";
    w3x.fillStyle = 'rgb(12, 64, 114)';
    w3x.beginPath();
    w3x.moveTo(25, 25);
    w3x.lineTo(175, 25);
    w3x.lineTo(175, 50);
    w3x.lineTo(200, 75);
    w3x.lineTo(175, 100);
    w3x.lineTo(175, 175);
    w3x.lineTo(25, 175);
    w3x.closePath();
    w3x.fill();
}
onload = init;

可悲的是,我只能使第一个画布元素(NHLRC)出现,而随后的画布( example.com/cwl等)不呈现。 该代码没有错,因为当我注释掉JS代码中的其他两个元素时,它可以正常工作,所以我错过了什么,做错了什么或发生了哪些冲突,导致每个canvas元素都无法在其对应的位置进行渲染页?

您的init函数职责过多(查找,验证和绘制)* 3。 当这些职责中的任何一项遇到失败(即找不到元素)时,显示就会停止。 在您的情况下w1, w2, w3只会在各自的页面中定义w1, w2, w3 ,而不是为每个页面定义。

您可以将其简化如下:

function draw(theCanvasEl, theFill) 
{ 
    var w1x = theCanvasEl.getContext('2d');
    w1x.shadowOffsetX = 0;
    w1x.shadowOffsetY = 0;
    w1x.shadowBlur = 20;
    w1x.shadowColor = "rgba(0, 0, 0, 0.75)";
    w1x.fillStyle = theFill;
    w1x.beginPath();
    w1x.moveTo(25, 25);
    w1x.lineTo(175, 25);
    w1x.lineTo(175, 50);
    w1x.lineTo(200, 75);
    w1x.lineTo(175, 100);
    w1x.lineTo(175, 175);
    w1x.lineTo(25, 175);
    w1x.closePath();
    w1x.fill();
}

function init()
{
  var canvases = [['ContentPlaceHolder2_canvasnhlrc', 'rgb(218, 233, 246)'],
     ['ContentPlaceHolder2_canvascwl', 'rgb(12, 64, 114)'],
     ['ContentPlaceHolder2_canvashslanguages', 'rgb(12, 64, 114)']];

   for(var i=0;i<canvases.length;i++)
   { 
       var theCanvas = document.getElementById(canvases[i][0]);
       if (theCanvas!=null) {
         draw(theCanvas, canvases[i][1]);
         break;              
       }
   }
}

onload = init;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM