0

Firebug を使用すると TypeError が発生します - スライスは関数ではありません。これは、文字列だと思っていたのに、数値にスライスを使用しようとしているためだと思います。

問題の文字列は"****01814c6538032b****"ajax コマンドを介してページに入力されますが、現時点ではテストのために宣言するだけです。

hexString = "****01814c6538032b****"

....そして最後に質問です!これを明示的に文字列として宣言する方法はありますか? toString を使用して変更することもできますが、最初に文字列として指定して、文字列のままにすることができるかどうか疑問に思いました。

** 編集 ** ここにすべての JavaScript コードがあります。コードの一部は hexString = から始まります。

<script type="text/javascript">

<!--
// Parses the xmlResponse from status.xml and updates the status box
function updateStatus(xmlData) {
    var mainstat = document.getElementById('display').style.display;
    var loadstat = document.getElementById('loading').style.display;

    // Check if a timeout occurred
    if(!xmlData)
    {
        mainstat = 'none';
        loadstat = 'inline';    

        return;
    }

    // Make sure we're displaying the status display
    mainstat = 'inline';
    loadstat = 'none';

    // Loop over all the LEDs
    for(i = 0; i < 5; i++)
        document.getElementById('led' + i).style.color = (getXMLValue(xmlData, 'led' + i) == '1') ? '#ff8b00' : '#777';

    // Loop over all the buttons
    for(i = 0; i < 5; i++)
        document.getElementById('btn' + i).innerHTML = (getXMLValue(xmlData, 'btn' + i) == 'up') ? '&Lambda;' : 'V';

    // Update the POT value
    for(i = 0; i < 2; i++)
        document.getElementById('pot'+i).innerHTML = getXMLValue(xmlData, 'pot'+i);

    // Update for bargraph
    for(i = 1; i < 3; i++)
    {
        var wd=0;
        wd= (getXMLValue(xmlData, 'pot'+(i-1)))/5;
        document.getElementById('bar'+i).style.width=wd+"px";
    }


    // Update string value
    document.getElementById('test').innerHTML =
    getXMLValue(xmlData, 'test');




var hexString="****01814c6538032b****";

s1 = hexString.slice(0,4);
document.getElementById("slice1").innerHTML=s1;
s2 = hexString.slice(4,6);
document.getElementById("slice2").innerHTML=h2d(s2);
s3 = hexString.slice(6,10);
document.getElementById("slice3").innerHTML=h2d(s3);
s4 = hexString.slice(10,14);
document.getElementById("slice4").innerHTML=h2d(s4);
s5 = hexString.slice(14,18);
document.getElementById("slice5").innerHTML=h2d(s5);
s6 = hexString.slice(18,22);
document.getElementById("slice6").innerHTML=s6;

tempString = h2d(s2);
sensorNo = parseInt(tempString); 

tempString = h2d(s3);
humVal = parseInt(tempString);

  HumidityTemp=(125/65536)*humVal;
  HumidityTemp=HumidityTemp-6;

document.getElementById("slice3").innerHTML=HumidityTemp.toString();


tempString = h2d(s4);
tempVal = parseInt(tempString);  

  TemperatureTemp=(175.72/65536)*tempVal;
  TemperatureTemp=TemperatureTemp-46.85;

  document.getElementById("slice4").innerHTML=TemperatureTemp.toString();

tempString = h2d(s5) ;
voltVal = parseInt(tempString);

  VoltageTemp = 2095/voltVal;

  document.getElementById("slice5").innerHTML=VoltageTemp.toString();



}
setTimeout("newAJAXCommand('status.xml', updateStatus, true)",500);


function h2d(h) 
{
return parseInt(h,16);

}



</script>
4

1 に答える 1

0

次のように、空の文字列を追加するだけで、数値を文字列に変換できます。

var str = 1+""; // === "1"

また、これは関連している可能性があります。

于 2012-10-31T14:37:22.550 に答える