- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直致力于使用如下例所示的条件语句来更改列中各个单元格的背景颜色,但我未能成功完成任何事情。我知道它可能设置不正确,而且我以前从未使用过 JavaScript。
document.getElementById("Table").onload = function();
Table.rows[1].cells[4].onload = function() {
let tableCell = var
if (tableCell > 92) {
document.body.style.backgroundColor = "green";
} else if ( tableCell > 90) {
document.body.style.backgroundColor = "orange";
} else {
document.body.style.backgroundColor = "red";
}
};
欢迎任何及所有帮助。
最佳答案
好的,在得到澄清后,请参阅此答案示例的第一部分以获取见解,第二部分以进一步学习。
首先,您只需将表格元素上的 onclick
更改为 onload
即可。仅针对此示例更改为 onclick
,但 onload
也会在您的项目上触发该方法一次。点击“运行片段”按钮后,继续单击示例中的表格以查看结果。
首先,您需要引用表对象来获取 HTMLTableCollection然后,您将首先循环行,然后循环每行的后续单元格。您可以在每次传递时从 innerHTML
获取数字值,并使用 parseInt
获取数字而不是字符串,然后您可以在每次迭代时通过 if 语句中的表达式进行比较,如下所示如示例所示。如果未传递数字,try
和 catch
block 将警告您脚本中的错误以进行更正。希望这对您有所帮助,并祝您好运!
parseCells = (theTable) => {
// First loop the table rows.
for(let r = 0, l = theTable.rows.length; r < l; r++) {
// Second loop the rows column cells.
for(let c = 0, e = theTable.rows[r].cells.length; c < e; c++) {
try {
// Giving a random number between for innerHTML 0-100 before referencing the cell in a variable for example.
theTable.rows[r].cells[c].innerHTML = Math.floor(Math.random() * 101);
// Get the contents and convert to number from string and set the current cell.
let currentCellNumber = parseInt(theTable.rows[r].cells[c].innerHTML),
currentCell = theTable.rows[r].cells[c];
// If the contents are numbers and can be parsed via expression then change colors.
if (currentCellNumber > 92) {
currentCell.style.backgroundColor = 'green';
} else if (currentCellNumber > 90) {
currentCell.style.backgroundColor = 'orange';
} else {
currentCell.style.backgroundColor = 'red';
}
}
// If there was error like cell contents aren't actually numbers, or table wasn't found etc, then alert via try/catch.
catch {
alert('Something is wrong with the input, are you sure your table cells only have numbers?')
}
}
}
}
td {
width: 5rem;
height: 5rem;
text-align: center;
vertical-align: middle;
border: gray 1px solid;
transition: background-color .35s ease;
}
<strong>Click repeatedly to watch the value/color changes</strong>
<table onclick="parseCells(this)">
<tr>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
</table>
为了学习,希望这对进一步有所帮助。干杯
const tablex = document.getElementById('theTable'),
clicked = document.getElementById('coordinates');
randomColor = () => {
return '#'+(Math.random()*0xFFFFFF<<0).toString(16);
}
colorMe = (that) => {
that.style.backgroundColor = randomColor();
clicked.innerHTML = that.parentNode.rowIndex + '/' + that.cellIndex;
}
colorCell = () => {
try {
const xInput = document.getElementById('theX'),
yInput = document.getElementById('theY'),
theCell = tablex.rows[xInput.value].cells[yInput.value];
theCell.style.backgroundColor = randomColor();
clicked.innerHTML = xInput.value + '/' + yInput.value;
} catch {
alert('Check your x/y buddy, there are not that many cells... 0 - 2');
}
}
td {
height: 5rem;
width: 5rem;
border: gray 1px dotted;
cursor: pointer;
pointer-events: all;
}
<strong>Click a box, or define one specifically below : <br/>
Most recently colored cell X/Y coordinates: <span id="coordinates" style="color:blue;font-size:130%"></span><br/>
<strong>Or a specific cell at a time;</strong><br/>
x: <input id="theX" type="number" maxlength="1">
y: <input id="theY" type="number" maxlength="1">
<button type="button" onclick="colorCell()">Color it</button>
<br/>
<table id="theTable">
<tr>
<td onclick="colorMe(this)"></td>
<td onclick="colorMe(this)"></td>
<td onclick="colorMe(this)"></td>
</tr>
<tr>
<td onclick="colorMe(this)"></td>
<td onclick="colorMe(this)"></td>
<td onclick="colorMe(this)"></td>
</tr>
<tr>
<td onclick="colorMe(this)"></td>
<td onclick="colorMe(this)"></td>
<td onclick="colorMe(this)"></td>
</tr>
</table>
关于javascript - 如何更改条件语句下单元格的颜色?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58070583/
我正在阅读 java swing,但在理解它时遇到问题。 Color 是一个类吗? Color[] col= {Color.RED,Color.BLUE}; 这在java中是什么意思? 最佳答案 Is
我正在研究用 python 编写的 pacman 程序。其中一个模块是处理吃 bean 游戏的图形表示。这当然是一些主机颜色。列表如下: GHOST_COLORS = [] ## establishe
本网站:http://pamplonaenglishteacher.com 源代码在这里:https://github.com/Yorkshireman/pamplona_english_teache
我最近将我的手机更新为 Android Marshmallow 并在其上运行了我现有的应用程序,但注意到颜色行为有所不同:将更改应用到 View (可绘制)的背景时,共享相同背景的所有 View (引
所有 X11/w3c 颜色代码在 Android XML 资源文件格式中是什么样的? I know this looks a tad ridiculous as a question, but giv
试图让 ffmpeg 创建音频波形,同时能够控制图像大小、颜色和幅度。我已经尝试过这个(以及许多变体),但它只是返回无与伦比的 "。 ffmpeg -i input -filter_complex "
我很好奇你是否有一些关于 R 中颜色酿造的技巧,对于许多独特的颜色,以某种方式使图表仍然好看。 我需要大量独特的颜色(至少 24 种,可能需要更多,~50 种)用于堆叠区域图(所以不是热图,渐变色不起
我看到的许多 WPF 示例和示例似乎都有硬编码的颜色。这些指南 - http://msdn.microsoft.com/en-us/library/aa350483.aspx建议不要硬编码颜色。在构建
我想更改文件夹的默认蓝色 如何设置? 最佳答案 :hi Directory guifg=#FF0000 ctermfg=red 关于Vim NERDTree 颜色,我们在Stack Overflow上
是否有关于如何将任意字符串哈希为 RGB 颜色值的最佳实践?或者更一般地说:3 个字节。 你问:我什么时候需要这个?这对我来说并不重要,但想象一下任何 GitHub 上的那些管图 network pa
我正在尝试将默认颜色设置为自定义窗口小部件。 这是有问题的代码。 class ReusableCard extends StatelessWidget { ReusableCard({this.
import javax.swing.*; import javax.swing.table.DefaultTableCellRenderer; import javax.swing.table.Ta
我有一个 less 文件来定义一堆颜色/颜色。每个类名都包含相关颜色的名称,例如 .colourOrange{..} 或 .colourBorderOrange{..} 或 navLeftButtOr
我有一个RelativeLayout,我需要一个黑色背景和一个位于其中间的小图像。我使用了这段代码: 其中@drawable/bottom_box_back是: 这样我就可以将图像居中了。但背
我需要设置 浅色 的 JPanel 背景,只是为了不覆盖文本(粗体黑色)。 此刻我有这个: import java.util.Random; .... private Random random =
我正在尝试制作一个自定义文本编辑器,可以更改特定键入单词的字体和颜色。如何更改使用光标突出显示的文本的字体和/或颜色? 我还没有尝试过突出显示部分。我尝试获取整个 hEdit(HWND) 区域并更改字
我想改变我整个应用程序的颜色。 在我的 AndroidManfiest.xml 中,我有正确的代码: 在 values 文件夹中,我有 app_theme.xml: @style/MyAc
是否可以使用 android 数据绑定(bind)从 xml 中引用颜色? 这很好用: android:textColor="@{inputValue == null ? 0xFFFBC02D : 0
有没有办法在 Android 应用程序中设置“空心”颜色? 我的意思是我想要一个带有某种背景的框,而文本实际上会导致背景透明。换句话说,如果整个 View 在蓝色背景上,文本将是蓝色的,如果它是红色的
我用CGContextStrokePath画在白色背景图片中的一条直线上,描边颜色为红色,alpha为1.0画线后,为什么点不是(255, 0, 0),而是(255, 96, 96)为什么不是纯红色?
我是一名优秀的程序员,十分优秀!