我正在创建一个表单并使输入字段只能使用JavaScript进行读取。我想将只读属性的默认颜色更改为绿色或黄色。
HTML
<input type="radio" name="sex" value="male">Male<br/>
<input type="radio" name="sex" value="female">Female <br/>
Age:<input type="text" name="age" id="age" size="20">
Hobbies:<input type="text" name="hobbies" id="hobbies" size="20"><br/>
Phone:<input type="text" name="phone" id="phone" size="20"><br/>
当有人点击女性时,ID为“年龄”和“手机”的输入将仅使用JavaScript进行阅读。
JS
$(function() {
$("input[name='sex']").change(function() {
if($(this).val() == "female") {
$("#age").attr("disabled", true);
style="backgroundcolor=green"
$("#phone").attr("disabled", true);
} else if($(this).val() == "male") {
$("#age").attr("disabled", false);
$("#phone").attr("disabled", false);
}
});
});
我想在只读时更改输入字段的颜色。
答案 0 :(得分:12)
只需使用:.css()
示例: http://jsfiddle.net/cL7ngmda/
$("input[name='sex']").change(function() {
if($(this).val() == "female") {
$("#age,#phone").attr("disabled", true).css("background-color","#0F0");
} else if($(this).val() == "male") {
$("#age,#phone").attr("disabled", false).css("background-color","#FFF");
}
});
<小时/> 另一种简单的方法是使用CSS 类:http://jsfiddle.net/e83s7s80/7/
<强> CSS 强>
.bg-green{
background-color:green;
}
<强> JS 强>
$("input[name='sex']").change(function() {
$("#age,#phone").attr("disabled", $(this).val() == "female").toggleClass("bg-green");
});
还有另一种使用CSS 选择器的简单方法。 : http://jsfiddle.net/dqgqjya5/3/
只需添加 css :
input:disabled{
background-color:green;
}
<强> JS 强>
$("input[name='sex']").change(function() {
$("#age,#phone").attr("disabled", $(this).val() == "female");
});
参考:https://developer.mozilla.org/en-US/docs/Web/CSS/:disabled
答案 1 :(得分:1)
$("#age").css('background-color', 'green');
OR
$(this).css('background-color', 'green');
答案 2 :(得分:0)
你可以试试这个:
$("input[name='sex']").change(function () {
if ($(this).val() == "female") {
$("#age").attr("disabled", true);
$("#age, #hobbies, #phone").css("background-color", "green");
$("#phone").attr("disabled", true);
} else if ($(this).val() == "male") {
$("#age").attr("disabled", false);
$("#phone").attr("disabled", false);
$("#age, #hobbies, #phone").css("background-color", "white");
}
});
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input type="radio" name="sex" value="male">Male
<br/>
<input type="radio" name="sex" value="female">Female
<br/>Age:
<input type="text" name="age" id="age" size="20">Hobbies:
<input type="text" name="hobbies" id="hobbies" size="20">
<br/>Phone:
<input type="text" name="phone" id="phone" size="20">
<br/>
&#13;
答案 3 :(得分:0)
为什么不使用css?
在css文件中定义一个禁用输入的样式,然后用你正在做的js禁用它们......
例如:
input[disabled] { background-color:#F00; }
答案 4 :(得分:0)
作为初学者,这是我改变输入字段背景颜色的解决方案。 我不确定这是不是最好的做法,但我想在这里与专家分享。
$("#name").focusin(function() {
$(this).addClass("green");
});
$("#name").blur(function() {
$(this).removeClass("green");
if (!$(this).val()) {
$(this).addClass("warning");
} else {
$(this).removeClass("warning");
$(this).addClass("green");
}
});
.warning {
background-color: red;
color: white;
}
.green {
background-color: rgba(144, 238, 144, 1);
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="formulier">
<form>
<div class="form-group row">
<label class="col-md-2">Name: </label>
<div class="col-md-6">
<input type="text" class="col-md-6" id="name" />
</div>
</div>
</form>
</div>