gpt4 book ai didi

javascript - 无法设置/读取未定义的属性

转载 作者:太空宇宙 更新时间:2023-11-04 05:08:26 25 4
gpt4 key购买 nike

我正在尝试制作一个“站点布局”类型的东西,您可以在其中单击一个属性和一个值,然后面板会更改为那个东西。我需要能够拥有一系列可以点击的界面。

我遇到错误无法设置/读取未定义的属性颜色

这是我的代码:

var panel = "";
var colorType = "texts";
var interfaces = new Array();
interfaces.push(new Interface());
var colors = 'black'
var idx = 0;

var interfaces = new Array();

function Interface(c)
{
this.colors = c;
}
function changeColor()
{
if(panel != '')
{
if(colorType == 'texts')
{
document.getElementById(panel).style.color = interfaces[idx].colors;
}
if(colorType == 'background')
{
document.getElementById(panel).style.backgroundColor = interfaces[idx].colors;
}
}
}
function changeSize()
{
document.getElementById(panel).style.fontSize = interfaces[idx].getElementById('fsizes').value +'px';
}
function panelClicked()
{
document.getElementById('texts').style.borderStyle = 'solid';
document.getElementById('background').style.borderStyle = 'none';
colors = 'black';
colorType = 'texts';
changeColor();
}

这是造成问题的 HTML:

<table style = "width:90px;">
<tr>
<td class = 'colors' style = "background-color:red;" onclick = "interfaces[idx].colors = 'red'; changeColor();"></td>
<td class = 'colors' style = "background-color:orange;" onclick = "interfaces[idx].colors = 'orange'; changeColor();"></td>
<td class = 'colors' style = "background-color:yellow;" onclick = "interfaces[idx].colors = 'yellow'; changeColor();"></td>
</tr>
<tr>
<td class = 'colors' style = "background-color:green;" onclick = "interfaces[idx].colors = 'green'; changeColor();"></td>
<td class = 'colors' style = "background-color:blue;" onclick = "interfaces[idx].colors = 'blue'; changeColor();"></td>
<td class = 'colors' style = "background-color:purple;" onclick = "interfaces[idx].colors = 'purple'; changeColor();"></td>
</tr>
<tr>
<td class = 'colors' style = "background-color:lightpink;" onclick = "interfaces[idx].colors = 'lightpink '; changeColor();"></td>
<td class = 'colors' style = "background-color:thistle;" onclick = "interfaces[idx].colors = 'thistle'; changeColor();"></td>
<td class = 'colors' style = "background-color:black;" onclick = "interfaces[idx].colors = 'black'; changeColor();"></td>
</tr>
</table>

最佳答案

您调用“var interfaces = new Array()”两次。如果你把它取出来,你应该没问题。

关于javascript - 无法设置/读取未定义的属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9865970/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com