jQuery对数组的操作_html/css_WEB-ITnose
回复讨论(解决方案)
类似手动选择彩票的基本功能.
我设计这功能
1,每个单元格自定义ID,例如1-1 就是tdid=1-1,3-1就是tdid=3-1.
2,每次点击给td add css.(背景色)
3,把这些操作写在.each里面每次点击.push()到数组.
4,如果要控制点击添加的长度在点击时控制length.
5,如果要设计已经添加的再次点击取消功能,要在点击时添加自定义属性aly=yes,aly=no再添加到数组.
function find(a, x, y) {
for(var i=0; i
return -1;
}
这个函数用于在数组中查找指定的记录,并返回对应的下标(没找到返回 -1)
var x = this.cellIndex; //取得单元格的列号(这是 dhtml 的,不是 jq 的)
var y = this.parentNode.rowIndex; //取得单元格所在行的行号(这是 dhtml 的,不是 jq 的)
var i = find(ar, x, y); //查找该单元格是否被点击过
if(i else ar[i][2]++; //否则计数加一
$('#view').html(JSON.stringify(ar)); //仅仅是为了观察一下,方便发现问题
你已经知道当前单元格被点击过几次了(ar[i][2])
那么还要做什么,就该自己动动脑筋了
function find(a, x, y) {
for(var i=0; i
return -1;
}
这个函数用于在数组中查找指定的记录,并返回对应的下标(没找到返回 -1)
var x = this.cellIndex; //取得单元格的列号(这是 dhtml 的,不是 jq 的)
var y = this.parentNode.rowIndex; //取得单元格所在行的行号(这是 dhtml 的,不是 jq 的)
var i = find(ar, x, y); //查找该单元格是否被点击过
if(i else ar[i][2]++; //否则计数加一
$('#view').html(JSON.stringify(ar)); //仅仅是为了观察一下,方便发现问题
你已经知道当前单元格被点击过几次了(ar[i][2])
那么还要做什么,就该自己动动脑筋了
function find(a, x, y) {
for(var i=0; i
return -1;
}
这个函数用于在数组中查找指定的记录,并返回对应的下标(没找到返回 -1)
var x = this.cellIndex; //取得单元格的列号(这是 dhtml 的,不是 jq 的)
var y = this.parentNode.rowIndex; //取得单元格所在行的行号(这是 dhtml 的,不是 jq 的)
var i = find(ar, x, y); //查找该单元格是否被点击过
if(i else ar[i][2]++; //否则计数加一
$('#view').html(JSON.stringify(ar)); //仅仅是为了观察一下,方便发现问题
你已经知道当前单元格被点击过几次了(ar[i][2])
那么还要做什么,就该自己动动脑筋了
$(function () {
ar = [];
$('td').click(function () {
var x = this.cellIndex + 1;
var y = this.parentNode.rowIndex + 1;
var i = find(ar, x, y);
//console.log(i);
if (i ar.push([x, y, 1]);
} else {
ar[i][2]++;
console.log(ar[i][2]);
var count = ar[i][2] % 3;
ar[i][2] = count;
switch (ar[i][2]) {
case 1: //点击1,4,7...3n+1下
$(this).css("background", "#228B22"); //绿色,栏位
break;
case 2: //点击2,5,8...3n+2下
$(this).css("background", "#555555"); //深灰色,通道
break;
case 0: //点击3,6,9...3n+0下
$(this).css("background", "#DAA520"); //橙色,舍中空白
break;
}
}
console.log(ar[i][2]);
console.log(ar);
console.log(x);
console.log(y);
console.log(i);
$('#view').html(JSON.stringify(ar));
});
function find(a, x, y) {
for (var i = 0; i if (a[i][0] == x && a[i][1] == y) return i;
return -1;
}
});
----------------------------------
为什么点第一下的时候,控制台报错???然后就没事了