| Asp编程 | PHP编程 | .Net编程 | Xml编程 | Access | Mssql | Mysql
用.Net实现基于CSS的AJAX开发(2)
2008-05-14 13:01 来源: 网络搜集 作者:阻击者整理 网友评论 0 条 浏览次数 0

好了,完成删除,,那么所有对应这个业务的删除都可以由命名为dgBigclassmanage的某一元素通过绑定delbtn样式来执行删

除(当然,这样不科学,不过是DEMO嘛,如果是实际你可以在QueryString里多传一个参数,在到AjaxDelRow派发后再用进行二次派发,然后以这个参数做标识就完美了)由于麻烦,,有兴趣的自己做吧。。 呵呵。

这个样式只依赖TABLE元素,所以DATAGRID、DATALIST、自己做的TABLE,自定义控件只要最后生成TABLE元素的控件都可以用。
主要提供一个思想,跟代码制作的好坏无关。在.NET里轻量地使用样式绑定,在有AJAX应用的开发中效果很棒。你也可以自己去实现一个更优秀的轻量框架了。

增删改、上下移动记录样式绑定的JS:

/**//**
* Written by Wangzhongyuan
*
* 这是一个样式驱动的功能按钮控制脚本,样式用法如下:
*
* 修改按钮样式: editgtn 应用样式后即可把目标元素变为修改按钮,目标行变为修改行并出现确定、取消按钮。
* 删除按钮样式: delbtn 应用样式后即可把目标元素变为删除按钮,点击删除则目标删除。
* 上移下移按钮样式: updownbtn 应用样式后即可把目标元素变为上移、下移元素,目标行变为可上移和下移。
*
* 其他需要样式正在制作中........
**/
var crudbtn = ...{
that: false,
isOdd: false,
lastAssignedId : 0,
addbtnid : 0,
newRows: -1,
init : function() ...{
// 首先, 查看浏览器是否能执行此脚本(有些浏览器不能用getElementsByTagName)
if (!document.getElementsByTagName) ...{
return;
}

this.that = this;

this.run();

},
/**//**
* 遍历document中的所有table,如果有样式crudtable,则应用此脚本
*
**/
run : function() ...{
var tables = document.getElementsByTagName("table");

for (var i=0; i < tables.length; i ) ...{
var thisTable = tables[i];

if (css.elementHasClass(thisTable, 'crudtable')) ...{
this.makecrudTable(thisTable);
}
}
},
/**//**
* 构建控制按钮
**/
makecrudTable : function(table) ...{

// 首先, 检测table是否有id,如果没有则创建
if (!table.id) ...{
table.id = 'crudTable' this.lastAssignedId ;
}
// 遍历表格的数据行
var newRows = new Array();
// 遍历表格所有数据行
for (var j = 0; j < table.tBodies[0].rows.length-1; j ) ...{
// 遍历数据行所有列
for(var k = 0;k < table.tBodies[0].rows[j 1].cells.length;k ) ...{
// 判断是否存在删除样式,如果存在则把该单元个转化为删除按钮
if(css.elementHasClass(table.tBodies[0].rows[j 1].cells[k], 'delbtn')) ...{
table.tBodies[0].rows[j 1].cells[k].id = 'delbtn' this.addbtnid ;
var linkEl = createElement('a');
linkEl.href = '#';
linkEl.onclick = this.delRow;
linkEl.setAttribute('columnId', k);

var innerEls = table.tBodies[0].rows[j 1].cells[k].childNodes;

linkEl.innerText = "删除";
table.tBodies[0].rows[j 1].cells[k].appendChild(linkEl);
}
// 判断是否存在修改样式,如果存在则把该单元个转化为修改按钮
if(css.elementHasClass(table.tBodies[0].rows[j 1].cells[k], 'editbtn')) ...{
table.tBodies[0].rows[j 1].cells[k].id = 'delbtn' this.addbtnid ;
var linkEl = createElement('a');
linkEl.href = '#';
linkEl.onclick = this.editRow;
linkEl.setAttribute('columnId', k);

var innerEls = table.tBodies[0].rows[j 1].cells[k].childNodes;

linkEl.innerText = "修改";
table.tBodies[0].rows[j 1].cells[k].appendChild(linkEl);
}
// 判断是否存在上移、下移样式,如果存在则把该单元个转化为上移、下移按钮
if(css.elementHasClass(table.tBodies[0].rows[j 1].cells[k], 'updownbtn')) ...{
table.tBodies[0].rows[j 1].cells[k].id = 'updownbtn' this.addbtnid ;

上一篇:用.Net实现基于CS    下一篇:用.Net实现基于CS

相关主题:

推荐下载

网友评论

关于我们 | 服务条款 | 隐私说明 | 意见反馈 | 业务合作 | 赞助我们 | 知识产权 | 使用帮助
CopyRight (2005-2008) | 抚州生活网 | VeryCMS 3.0 备案号:赣ICP备06005705号