美好的一天,jQuery添加css类
我有一个以一行数据开头的HTML表格。每行有一个下拉菜单和五个输入文本框。在行的末尾是一个图像,点击时将克隆最后一行并删除文本框中的任何数据。客户希望能够根据需要创建尽可能多的行。
我有一些JavaScript/jQuery循环彻底的每一行,并根据每个选择/输入控件的名称属性动态创建一个对象。此外,我想验证数字字段(浮点数或整数)。 这是正常工作。问题是验证失败时,我想在输入文本周围绘制红色边框。
这里是我的代码:
$("input.submit").on('click', function(e) {
var billingDetailRows = [];
var detailRows = [];
$('.miBillingDetails tbody tr').each(function(i, row) {
// http://stackoverflow.com/questions/9132347/iterating-through-table-cells-using-jquery
// The 'this' is necessary to ensure you only iterate through the row you're currently on
var detailRow = {};
var isNumeric = false;
var dataType = '';
$('td', this).each(function(e) {
var domElement = $(this).find(':input');
var attrName = '';
if (typeof domElement != 'undefined') {
attrName = domElement.attr('name');
if (typeof attrName != 'undefined')
console.log(attrName);
}
var dataType = domElement.attr('data-type');
if (typeof dataType != 'undefined') {
isNumeric = dataType === 'numeric';
dataType = domElement.attr('data-format');
}
var value = $(this).find(':input').val();
if (typeof value != 'undefined') {
console.log(value === '' ? 'NONE' : value);
var actualValue = value === '' ? '' : value;
if (isNumeric && actualValue.length > 0) {
if (!validateNumber(actualValue, dataType === 'int')) {
$(domElement).css({
"border-color": "#FF0000",
"border-width": "1px",
"border-style": "solid"
});
// $(domElement).addClass("errorBorder");
}
}
detailRow[attrName] = actualValue;
}
});
detailRows.push(detailRow);
})
});
.errorBorder {
thin solid #FF0;
}
<table class="miBillingDetails">
<tr>
<td>
<select name="RevenueType">
<option value="Cash">Cash</option>
<option value="CC">Credit Card</option>
<option value="Visa">Visa</option>
</select>
</td>
<td>
<input type="text" name="BillingRate" data-type="numeric" data-format="float">
</td>
<td>
<input type="text" name="Quantity" data-type="numeric" data-format="int">
</td>
<td>
<input type="text" name="FlatRate" data-type="numeric" data-format="float">
</td>
<td>
<input type="text" name="SequenceStart">
</td>
<td>
<input type="text" name="SequenceEnd">
</td>
<td>
<img class="cloneWars" src="images/add2.jpg" alt="Add Tag" />
</td>
</tr>
</table>
的问题,我想用addClass/removeClass。但无论如何,这是行不通的。我必须设置CSS才能工作。
我在做什么错?
TIA,
COSON
你还试过''domElement.addClass(“errorBorder”);''? –
您确定您有该规则的有效css定义吗?对我来说似乎不是这样 –
@BettySt他有这样的评论,我相信他已经试过 – stackoverfloweth