- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已将复选框分配给颜色。昨天我添加了 8 种颜色,今天早上又添加了 2 种。我复制了其他颜色的代码,我只是更改了值以将其分配给好的颜色。我的问题是,对于粉色和橙色,我收到错误消息 TypeError: Cannot read property 'checked' of null 在 myFunc ( https://replit.org/data/web_hosting/NoobCode/Color/index.js:36:24 ) 在 HTMLTableCellElement.onclick ( https://replit.org/data/web_hosting/NoobCode/Color/:238:36 )
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<title>repl.it</title>
<link href="index.css" rel="stylesheet" type="text/css" />
</head>
<body>
Black<input type="checkbox" id="BLACK">
___Blue<input type="checkbox" id="BLUE">
___Red<input type="checkbox" id="RED">
___Yellow<input type="checkbox" id="YELLOW">
___Green<input type="checkbox" id="GREEN">
___Purple<input type="checkbox" id="PURPLE">
___Brown<input type="checkbox" id="BROWN">
___Pink<input type="checkbox" id="PINK">
___Orange<input type="checkbox" id="ORANGE">
___Erase<input type="checkbox" id="PINK">
在我有很多时间做同样事情的 table 之后
<table >
<tr>
<th onclick="myFunc(this)"></th>
<th onclick="myFunc(this)"></th>
</tr>
</table>
CSS
td, th
{
border:solid black 1px;
width:950px;
height:26px;
}
table
{
border-collapse: collapse;
}
.thBlack
{
background-color:Black;
}
.thBlue
{
background-color:royalblue;
}
.thYellow
{
background-color:yellow;
}
.thRed
{
background-color:#f72213;
}
.thGreen
{
background-color:green;
}
.thPurple
{
background-color:purple;
}
.thBrown{
background-color:#6b461a;
}
.thWhite{
background-color:white;
}
.thOrange{
background-color:#ff8c00;
}
.thPink{
background-color:hotpink;
}
Javascript
var checkBLACK = document.getElementById("BLACK");
var checkBLUE = document.getElementById("BLUE");
var checkRED= document.getElementById("RED");
var checkYELLOW = document.getElementById("YELLOW");
var checkGREEN = document.getElementById("GREEN");
var checkPURPLE = document.getElementById("PURPLE");
var checkBROWN = document.getElementById("BROWN");
var checkPINK = document.getElementById("PINK");
var checkORANGE = document.getElementById("ORANGE");
var checkWHITE = document.getElementById("WHITE");
function myFunc(elem) {
if (checkBLUE.checked == true){
elem.classList.toggle("thBlue");
}
else if(checkBLACK.checked == true){
elem.classList.toggle("thBlack");
}
else if(checkGREEN.checked == true){
elem.classList.toggle("thGreen");
}
else if(checkYELLOW.checked == true){
elem.classList.toggle("thYellow");
}
else if(checkRED.checked == true){
elem.classList.toggle("thRed");
}
else if(checkPURPLE.checked == true){
elem.classList.toggle("thPurple");
}
else if(checkBROWN.checked == true){
elem.classList.toggle("thBrown");
}
else if(checkWHITE.checked == true){
elem.classList.toggle("thWhite");
}
else if(checkORANGE.checked == true){
elem.classList.toggle("thOrange");
}
else if(checkPINK.checked == true){
elem.classList.toggle("thPink");
}
}
最佳答案
如果你检查你的 repl 错误,错误似乎在你函数的第 36 行。这行在这里:
else if(checkWHITE.checked == true){
var checkWHITE
定义为:
var checkWHITE = document.getElementById("WHITE");
但是 document.getElementById("WHITE");
返回 null
发生这种情况是因为您没有任何 ID 为 WHITE 的元素只有这些颜色:
Black<input type="checkbox" id="BLACK">
___Blue<input type="checkbox" id="BLUE">
___Red<input type="checkbox" id="RED">
___Yellow<input type="checkbox" id="YELLOW">
___Green<input type="checkbox" id="GREEN">
___Purple<input type="checkbox" id="PURPLE">
___Brown<input type="checkbox" id="BROWN">
___Pink<input type="checkbox" id="PINK">
___Orange<input type="checkbox" id="ORANGE">
___Erase<input type="checkbox" id="PINK">
所以只需将它添加到您的 html 中:
___White<input type="checkbox" id="ORANGE">
一切都应该工作正常
关于javascript - 选中复选框问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49349308/
谁知道现成的脚本或插件提供: -Shift click for check/uncheck all in range -CTRL click to select or unselect all 这可以
如果您点击按钮,它会打开 3 个复选框(一个选择全部,还有两个子输入)。 我想做的是,如果用户点击Centro de dia,输入将保持选中状态,而另一个(在本例中为button)会被选中未经检查。如
我正在学习 Wes Bos 30 天 Javascript 类(class),在一项可选功能上,我需要在底部添加三个按钮:清除全部、选中全部和取消选中全部。这是代码
自从升级到 jquery 1.9 以来,我的脚本停止了检查/取消选中复选框的工作。 我有一个主复选框,用于控制选择/检查表中的复选框列表。升级到新的 jquery 版本后,仅最初单击“检查全部”复选框
我有一个带有复选框列的表格,我添加了以下内容: 这是我的 jQuery 函数: jQuery(document).ready(function() { jQuery('#selec
这是我所拥有的(此处使用 Twitter bootstrap) #html fdsfdsfds
这个问题已经有答案了: Setting "checked" for a checkbox with jQuery (44 个回答) 已关闭 6 年前。 当我单击“问题”时,必须选择/取消选择两个复选框
我有这个表格: First Second Third --- Option1 Option2 有没有办法(使用 JS/jQuery)我可以在 First 时将 first
我试图有一个复选框来选中/取消选中所有其他复选框。 我正在使用此代码: $("#checkall").toggle( function () { $(".kselItems
在复选框列表中,应该可以通过按下按钮来选中/取消选中所有项目。但是下面的代码只能部分工作: All None
当我执行代码时,我得到 4 个复选框,我检查/选择了所有 4 个复选框,当我尝试调试代码时,它确实算作我有 4 个复选框,但所有 4 个复选框都被选中 = false。 我在代码中缺少什么? Li
$("input[type='radio']").each(function() { if ($(this).is(":checked")) { $(this).css('backgrou
我无法使用此 javascript 函数。任何帮助将不胜感激! No function yesno(thecheckbox, thelabel){ var ch
这是我的第一个 js 脚本,请对我温柔点:) 问题是当我点击选中所有按钮时,所有复选框都被选中但它不会将值写入文本区域,如果我单击单个复选框然后值被添加/删除并且没关系,我只是卡住了在那个选中所有/取
我试图在复选框处于选中状态或未选中状态时传递一个值。 但是,它似乎没有通过非检查状态。我正在使用的代码如下: if (document.getElementById('PRODUCT_REVIEW_E
目前我正在使用它来选中/取消选中表单中的所有复选框。 checked=false; function checkedAll (frm1) { var aa= document.getElem
我有 2 个单选按钮,当我单击其中一个按钮时,我会看到下拉菜单,必须在其中选择金额。 到目前为止,我能够检查/取消检查它们,但问题是,当我取消检查单选按钮下拉列表时,不会再次隐藏。 我不太擅长 Jav
HTML: Select All 1. 2. 3. 4. 5. JS: function test(click
我需要为每套图书设置一个选中/取消选中全部复选框。它还应该加上总价和重量。到目前为止,我只能选中每个框,它会很好地添加值,但是一旦我添加一个函数来选中所有框,一切都会停止工作。 //check all
我正在尝试根据来自 mysql 数据库的数据来选中或取消选中复选框。我使用nusoap webservice/webclient读取数据,数据值可以是1或0。 我的代码是: functio
我是一名优秀的程序员,十分优秀!