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') ? 'Λ' : '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>