欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于jquery的動態(tài)創(chuàng)建表格的插件

 更新時間:2011年04月05日 20:40:55   作者:  
工作快一年了,最近學習jquery,對jquery很感興趣。第一次寫博客,有不足之處還請各位拍磚。
廢話少說直接進入主題,
表格功能:
1、添加
2、刪除
3、獲取值
4、動態(tài)填充數據
5、動態(tài)設置焦點
6、鍵盤左右上下鍵控制單元格焦點
7、單元格添加正則驗證功能
WebForm4.aspx
復制代碼 代碼如下:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm4.aspx.cs" Inherits="table.WebForm4" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title></title>
<script src="jquery-1.3.2-vsdoc2.js" type="text/javascript"></script>
<script src="jquery-1.3.2.js" type="text/javascript"></script>
<script src="jquery.DynamicTable.js" type="text/javascript"></script>
<link href="style2.css" type="text/css" rel="Stylesheet"/>
<script type="text/javascript">
var rowtmplate = "<tr><td class='TableData'><input type='text' style='border:0px; width:98%;'/></td>";
rowtmplate += "<td class='TableData'><input type='text' style='border:0px; width:98%;'/></td>";
rowtmplate += "<td class='TableData'><input type='text' style='border:0px; width:98%;'/></td>";
rowtmplate += "<td class='TableData'><input type='text' style='border:0px; width:98%;'/></td>";
rowtmplate += "<td class='TableData'><input type='text' style='border:0px; width:98%;'/></td>";
rowtmplate += "<td class='TableData'><a href='#' >刪除</a></td></tr>";
$(document).ready(function() {
$(this).bind('keyup', function(e) {
switch (e.keyCode) {
case 38: //上 ↑
var arr = $.fn.getFocus();
var rowIndex = arr[0] - 1;
$.fn.setFocus({ rowIndex: rowIndex, colIndex: arr[1] });
$.fn.setCellsFocus();
break;
case 40: //下 ↓
var arr = $.fn.getFocus();
var rowIndex = arr[0] + 1;
$.fn.setFocus({ rowIndex: rowIndex, colIndex: arr[1] });
$.fn.setCellsFocus();
break;
default:
break;
}
});
$('#mytbl').DynamicTable({
rowCount: 3, //添加行數
identity: 1, //第1列自動編號
arrFocus: [2, 1], //第一個單元格設置為焦點
rowTmplate: rowtmplate //行模版
});
$('#mytbl').BindEvent({
eventName: "click",
colIndex: 1,
fn: alertMsg
}); //默認給第一列綁定click事件
$('#mytbl').setCellsFocus(); //設置第一個單元格為焦點
$('#mytbl').deleteRow(); //默認給第6列綁定刪除事件
$('#mytbl').AutoFillData({ colIndex: 2, fn: getData }); //默認給第二列綁定自動填充數據
$('#mytbl').Identity({ colIndex: 1 }); //默認給第一列自動排序
$('#mytbl').validationText({ reg: /^((\d+\.\d{2})|\d+)$/, colIndex: 5, defalutValue: 0.00 }); //默認給第二列添加驗證(只能輸入money格式)
});
//添加行
function addRow(count) {
$('#mytbl').addRow({ rowCount: count });
$('#mytbl').Identity();
$.fn.deleteRow();
}
//獲取自動填充數據
function getData(key) {
var arr = [];
arrFoucs = $.fn.getFocus();
$.ajax({
type: "post",
async: false, //控制同步
url: "getData.ashx",
dataType: "json",
cache: false,
success: function(data) {
var idx = arrFoucs[0] - 2;
arr.push(data[idx].id);
arr.push(data[idx].Name);
arr.push(data[idx].Code);
arr.push(data[idx].Units);
arr.push(data[idx].Price);
},
Error: function(err) {
alert(err);
}
});
$.fn.setCellsFocus({ rowIndex: arrFoucs[0], colIndex: 4 });
return arr;
}
function alertMsg() {
arrFoucs = $.fn.getFocus();
alert('你單擊了坐標X:'+arrFoucs[0]+' Y:'+arrFoucs[1]+'的單元格');
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<table cellpadding="0" cellspacing="0" class="tablestyle1" id="mytbl">
<tr>
<td class="TableData">序號</td>
<td class="TableData">產品名稱</td>
<td class="TableData">產品代碼</td>
<td class="TableData">單位</td>
<td class="TableData">單價</td>
<td class="TableData"><a href="#" onclick="addRow(5);">添加5行</a></td>
</tr>
</table>
<input type="button" value="獲取值" onclick="javascript:alert($.fn.getValue({}));" />
</div>
</form>
</body>
</html>

jquery.DynamicTable.js
復制代碼 代碼如下:

///<reference path="jquery-1.3.2-vsdoc2.js" />
2
3 (function($) {
4 var rowtmplate = "";
5 var arrFocus = [];
6
7 $.fn.DynamicTable = function(options) { //定義插件的名稱,這里為userCp
8 var deafult = {
9 //以下為該插件的屬性及其默認值
rowCount: 5, //添加行數
identity: 1, //第1列自動編號
arrFocus: [2, 1], //第一個單元格設置為焦點
rowTmplate: "" //行模版
};
var ops = $.extend(deafult, options);
rowtmplate = ops.rowTmplate;
arrFocus = ops.arrFocus;
$(this).addRow(ops.rowCount);
};
/*通過行模版添加多行至表格最后一行后面*/
/*count--添加行數*/
$.fn.addRow = function(options) {
var deafult = {
rowCount: 5
};
var ops = $.extend(deafult, options);
var rowData = "";
var count = ops.rowCount;
for (var i = 1; i <= count; i++) {
rowData += rowtmplate;
}
$(this).find('tr:last-child').after(rowData);
CellsFocus();
};
/*動態(tài)給某列綁定事件,事件被觸發(fā)時執(zhí)行fn函數*/
/*eventName--事件名稱;colIndex--列索引(從1開始);fn--觸發(fā)函數*/
$.fn.BindEvent = function(options) {
var deafult = {
eventName: 'click',
colIndex: 1,
fn: function() { alert('你單擊了此單元格!') }
};
var ops = $.extend(deafult, options);
eventName = ops.eventName;
colIndex = ops.colIndex;
fn = ops.fn;
$("tr:gt(0) td:nth-child(" + colIndex + ")").bind(eventName, fn);
};
/*給某列綁定單擊刪除事件*/
/*colIndex--列索引(從1開始)*/
$.fn.deleteRow = function(options) {
var deafult = {
colIndex: 6
};
var ops = $.extend(deafult, options);
var colIndex = ops.colIndex;
$("tr:gt(0) td:nth-child(" + colIndex + ")").bind("click", function() {
var obj = $(this).parent(); //獲取tr子節(jié)點對象
if (confirm('您確定要刪除嗎?'))
obj.remove();
});
};
/*自動給指定列填充序號*/
/*colIndex--列索引(從1開始)*/
$.fn.Identity = function(options) {
var deafult = {
colIndex: 1
};
var ops = $.extend(deafult, options);
var colIndex = ops.colIndex;
var i = 1;
$("td:nth-child(" + colIndex + ")").find('input').each(function() {
$(this).attr('value', i)
i++;
});
};
/*獲取焦點單元格坐標*/
$.fn.getFocus = function() {
return arrFocus;
};
/*設置焦點單元格坐標*/
/*rowIndex--行索引(從1開始);colIndex--列索引(從1開始)*/
$.fn.setFocus = function(options) {
var deafult = {
rowIndex: 2,
colIndex: 1
};
var ops = $.extend(deafult, options);
var rowIndex = ops.rowIndex;
var colIndex = ops.colIndex;
arrFocus[0] = rowIndex;
arrFocus[1] = colIndex;
};
/*當某個單元格中輸入數據,按Enter鍵后自動根據輸入的值從后臺檢索數據填充到該行對應列*/
/*colIndex--第幾列輸入數據按Enter鍵觸發(fā)事件;fn--帶參的回調函數*/
$.fn.AutoFillData = function(options) {
colIndex = options.colIndex;
fn = options.fn;
$("td:nth-child(" + colIndex + ")").bind("keyup", function() {
var obj = $(this).parent(); //獲取tr子節(jié)點對象
$(this).find('input').each(function() {
if (event.keyCode == 13) {
var vl = $(this).val();
var arr = new Array();
arr = fn(vl);
var i = 0;
obj.find("td").each(function() {
$(this).find("input").each(function() {
$(this).attr('value', arr[i]);
i++;
});
});
}
});
});
};
/*設置某個單元格為焦點*/
/*rowIndex--行索引(從1開始);colIndex--列索引(從1開始)*/
$.fn.setCellsFocus = function(options) {
var deafult = {
rowIndex: arrFocus[0],
colIndex: arrFocus[1]
};
var ops = $.extend(deafult, options);
var rowIndex = ops.rowIndex;
var colIndex = ops.colIndex;
$("tr:nth-child(" + rowIndex + ") td:nth-child(" + colIndex + ")").each(function() {
$(this).find('input').each(function() {
$(this)[0].focus();
$(this).attr('value', $(this).attr('value'));
arrFocus = [];
arrFocus.push(rowIndex);
arrFocus.push(colIndex); //更新焦點數組值
});
});
};
/*設置某個單元格文本值為選中狀態(tài)*/
/*rowIndex--行索引(從1開始);colIndex--列索引(從1開始)*/
$.fn.setCellsSelect = function(options) {
var deafult = {
rowIndex: arrFocus[0],
colIndex: arrFocus[1]
};
var ops = $.extend(deafult, options);
var rowIndex = ops.rowIndex;
var colIndex = ops.colIndex;
$("tr:nth-child(" + rowIndex + ") td:nth-child(" + colIndex + ")").each(function() {
$(this).find('input').each(function() {
$(this)[0].select();
});
});
};
/*某個單元格添加驗證功能*/
/*reg--正則表達式;colIndex--列索引(從1開始);defaultValue--驗證失敗默認給單元格賦值*/
$.fn.validationText = function(options) {
var deafult = {
reg: /^((\d+\.\d{2})|\d+)$/,
colIndex: 2,
defaultValue: 0
};
var ops = $.extend(deafult, options);
var reg = ops.reg;
var colIndex = ops.colIndex;
var defaultValue = ops.defaultValue;
$("tr:gt(0) td:nth-child(" + colIndex + ")").each(function() {
$(this).find('input').each(function() {
//驗證
$(this).bind('blur', function() {
var vl = $(this).attr('value');
if (!reg.test(vl))
$(this).attr('value', defaultValue);
});
});
});
};
/*獲取表格中的值*/
$.fn.getValue = function(options) {
var deafult = {
rowIndex: 0, //行坐標(從2開始)
colIndex: 0 //列坐標(從1開始)
};
var ops = $.extend(deafult, options);
rowIndex = ops.rowIndex;
colIndex = ops.colIndex;
var val = "";
if (rowIndex == 0) { //獲取所有行的數據
$('tr:gt(0)').each(function() {
$(this).find("td").each(function() {
$(this).find("input").each(function() {
val += $(this).attr('value') + "&";
});
});
val = val.substring(0, val.length - 1) + "|";
});
}
else {
if (colIndex == 0) { //獲取某行數據
$('tr:nth-child(' + rowIndex + ')').each(function() {
$(this).find("td").each(function() {
$(this).find("input").each(function() {
val += $(this).attr('value') + "&";
});
});
val = val.substring(0, val.length - 1) + "|";
});
}
else { //獲取某個單元格的值
$("tr:nth-child(" + rowIndex + ") td:nth-child(" + colIndex + ")").each(function() {
$(this).find('input').each(function() {
val += $(this).attr('value');
});
});
}
}
return val;
};
/*某個單元格獲取焦點后更新焦點坐標*/
function CellsFocus() {
var colCount = $("tr:nth-child(1) td").size(); //獲取每行共有多少個單元格
$("tr:gt(0) td").each(function() {
var obj = $(this);
$(this).find('input').each(function() {
$(this).bind('focus', function() {
var cellTotal = $('td').index(obj); //獲取某單元格的索引
arrFocus[0] = parseInt(cellTotal / colCount) + 1; //第幾行
arrFocus[1] = cellTotal % colCount + 1; //第幾列
});
});
});
};
})(jQuery);

getData.ashx
復制代碼 代碼如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
namespace table
{
/// <summary>
/// $codebehindclassname$ 的摘要說明
/// </summary>
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
public class getData : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
context.Response.Clear();
string value = GetResult();
context.Response.Write(value);
context.Response.End();
}
private string GetResult()
{
string result = string.Empty;
result = @"
[{""id"":""1"",""Name"":""綠茶"",""Code"":""1371"",""Units"":""斤"",""Price"":""200""},
{""id"":""2"",""Name"":""紅茶"",""Code"":""1372"",""Units"":""斤"",""Price"":""300""},
{""id"":""3"",""Name"":""茶具"",""Code"":""1373"",""Units"":""臺"",""Price"":""20000""},
{""id"":""4"",""Name"":""鐵觀音"",""Code"":""1374"",""Units"":""瓶"",""Price"":""400""},
{""id"":""5"",""Name"":""袋泡茶"",""Code"":""1375"",""Units"":""盒"",""Price"":""500""},
{""id"":""6"",""Name"":""茶食品"",""Code"":""1376"",""Units"":""盒"",""Price"":""400""},
{""id"":""7"",""Name"":""包裝袋"",""Code"":""1377"",""Units"":""盒"",""Price"":""100""}]";
return result;
}
public bool IsReusable
{
get
{
return false;
}
}
}
}

style2.css
復制代碼 代碼如下:

/* ---------- 頁面樣式定義 ---------- */
body
{
background-color:#ffffff;
MARGIN:0px;
font-size: 10pt; /* 字體大小 */
font-family:Verdana; /* 字體名稱 */
}
/* ---------- 文字鏈接 - 鏈接的普通狀態(tài) ---------- */
A:link {
color: #0000FF;
TEXT-DECORATION: none;}
/* ---------- 文字鏈接 - 已被訪問鏈接 ---------- */
A:visited {
COLOR: #0000FF;
TEXT-DECORATION: none}
/* ---------- 文字鏈接 - 處于活動狀態(tài)鏈接 ---------- */
A:active {
COLOR: #3333ff;
TEXT-DECORATION: none}
/* ---------- 文字鏈接 - 指針在鏈接上 ---------- */
A:hover {
COLOR: #ff0000;
text-decoration: underline;}
/* ---------- 表格樣式1(普通表格) ---------- */
.tablestyle1{
font-size: 9pt; /* 表格內字體大小 */
width: 100%; /* 表格寬度 */
border: 0px none; /* 表格邊框寬度 */
background-color: #0077B2; /* 表格線顏色 */
cellSpacing:expression(this.cellSpacing=1); /* 兩個單元格之間的距離 */
cellPadding:expression(this.cellPadding=3); }
.TableData {
BACKGROUND: #FFFFFF;
FONT-SIZE: 10pt;
}

由于不知道怎么上傳文件 所以只好把代碼貼出來 請各位見諒?。?!

相關文章

  • jQuery實現Table分頁效果

    jQuery實現Table分頁效果

    這篇文章主要為大家詳細介紹了jQuery實現Table分頁效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • jQuery實現 上升、下降、刪除、添加一行代碼

    jQuery實現 上升、下降、刪除、添加一行代碼

    這篇文章主要介紹了jQuery實現 上升、下降、刪除、添加一行代碼的實現方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-03-03
  • jQuery插件select2利用ajax高效查詢大數據列表(可搜索、可分頁)

    jQuery插件select2利用ajax高效查詢大數據列表(可搜索、可分頁)

    select2是一款jQuery插件,是普通form表單select組件的升級版。 接下來通過本文給大家介紹jQuery插件select2利用ajax高效查詢大數據列表(可搜索、可分頁),需要的的朋友參考下吧
    2017-05-05
  • 基于jQuery實現的單行公告活動輪播效果

    基于jQuery實現的單行公告活動輪播效果

    本文通過實例代碼給大家介紹了基于jQuery實現的單行公告活動輪播效果,非常不錯,代碼簡單易懂,具有參考借鑒價值,需要的的朋友參考下吧
    2017-08-08
  • jquery 判斷div show的狀態(tài)實例

    jquery 判斷div show的狀態(tài)實例

    下面小編就為大家?guī)硪黄猨query 判斷div show的狀態(tài)實例。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,祝大家游戲愉快哦
    2016-12-12
  • jQuery語法小結(超實用)

    jQuery語法小結(超實用)

    這篇文章主要介紹了jQuery語法小結(超實用),涉及到jquery語法相關知識,對jquery語法相關知識感興趣的朋友一起學習吧
    2015-12-12
  • DOM事件階段以及事件捕獲與事件冒泡先后執(zhí)行順序(圖文詳解)

    DOM事件階段以及事件捕獲與事件冒泡先后執(zhí)行順序(圖文詳解)

    DOM事件標準定義了兩種事件流,這兩種事件流有著顯著的不同并且可能對你的應用有著相當大的影響。這兩種事件流分別是捕獲和冒泡。和許多Web技術一樣,在它們成為標準之前,Netscape和微軟各自不同地實現了它們,下面介紹DOM事件階段以及事件捕獲與事件冒泡先后執(zhí)行順序
    2015-08-08
  • JQuery中getJSON的使用方法

    JQuery中getJSON的使用方法

    最近有一個活動,其中的數據需要和純靜態(tài)html網站進行交互。但是由于兩個網站處于不同的域名下,而Ajax的應用中,由于安全的問題,瀏覽器默認是不支持跨域調用的,最后選用了JQuery中的getJSON方法
    2010-12-12
  • 超級有用的13個基于jQuery的內容滾動插件和教程

    超級有用的13個基于jQuery的內容滾動插件和教程

    這篇文章與大家分享13個超級有用的 jQuery 內容滾動插件和教程。您可能經常能看到一些網站上特色區(qū)域的內容以滾動方式變化,這是一種在有限的網頁空間內展示更多內容的良好方式,而且能吸引用戶注意力。
    2011-07-07
  • jQuery實現動態(tài)加載(按需加載)javascript文件的方法分析

    jQuery實現動態(tài)加載(按需加載)javascript文件的方法分析

    這篇文章主要介紹了jQuery實現動態(tài)加載(按需加載)javascript文件的方法,結合實例形式分析了jQuery根據調用函數按需動態(tài)加載javascript文件相關實現技巧,需要的朋友可以參考下
    2019-05-05

最新評論