jquery 应用代码 方便的排序功能 |
本文标签:jquery,排序功能 终极目的:想做一个方便的排序功能 。 具体实现:点击后可以输入排序的数字编号,移开后自动更新数据库 。 1,我想把这个功能用<span>来完成,也就需要一个在页面上监控指定的span的东西,他就是: ready(fn)当DOM载入就绪可以查询及操纵时绑定一个要执行的函数 。 $(document).ready(function(){ // 在这里写你的代码... }); 2,页面上<span>很多,如何才能区分呢?用id?还是class?id太单一,于是用class,因为排序不是针对一条数据,而是多条 。 <span class="BY">3</span><br /><BR><span class="BY">2</span><br /><BR><span class="BY">1</span><br /><BR><span class="BY">0</span><br /> 3,绑定的事件我想肯定是click $(document).ready(function(){<BR> $(".BY").click(function() {<BR> alert(测试下先);<BR> });<BR><BR>}); <BR> 4,然后要让span变成一个输入框才行,go 复制代码 代码如下: $(document).ready(function(){ $(".BY").click(function() { var old = $(this).text(); var o = $(this); o.html("<input class=\"OnBY\" type=\"text\" value=\"" + old + "\"/>"); }); }); 5,这时发现了一个 问题,无法点击的 。点了之后数字没了 。因此就无法输入更改了 。想个什么办法呢?还记得自动获取选择么? 复制代码 代码如下: $(document).ready(function(){ $(".BY").click(function() { var old = $(this).text(); var o = $(this); o.html("<input class=\"OnBY\" type=\"text\" onMouseOver=\"this.select();\" value=\"" + old + "\"/>"); }); }); 6,很简单的可以更改了 。不过当鼠标移开的时候,不能变回去了 。郁闷,咋整? 复制代码 代码如下: $(document).ready(function(){ $(".BY").click(function() { var old = $(this).text(); var o = $(this); o.html("<input class=\"OnBY\" type=\"text\" onMouseOver=\"this.select();\" value=\"" + old + "\"/>"); $(".OnBY").blur(function() { o.html($(".OnBY").val()); }); }); }); 用失去焦点函数,把html代码替换回来就是 。换回来的还是修改的值 。 7,不过 不能更数据库交涉,接下来就要用到ajax 。看看 。 复制代码 代码如下: $(document).ready(function(){ $(".BY").click(function() { var old = $(this).text(); var o = $(this); o.html("<input class=\"OnBY\" type=\"text\" onMouseOver=\"this.select();\" value=\"" + old + "\"/>"); $(".OnBY").blur(function() { $.ajax({ type: "GET", url: "Admin_BY.aspx", data: "BY=" + $(".OnBY").val(), success: function(msg) { alert(msg); o.html($(".OnBY").val()); } }); }); }); }); 把修改的By参数提交给Admin_BY.aspx处理,后台的处理我就不多说了 。用Requst.QueryString来获取 。 8,再改进一下,排序肯定要指定一个数据ID <span class="BY" DbID="3" title="点击修改">3</span><br /> <span class="BY" DbID="2" title="点击修改">2</span><br /> <span class="BY" DbID="1" title="点击修改">1</span><br /> <span class="BY" DbID="0" title="点击修改">0</span><br /> 复制代码 代码如下: $(document).ready(function(){ $(".BY").click(function() { var old = $(this).text(); var o = $(this); o.html("<input class=\"OnBY\" type=\"text\" onMouseOver=\"this.select();\" value=\"" + old + "\"/>"); $(".OnBY").blur(function() { $.ajax({ type: "GET", url: "Admin_BY.aspx", data: "ID=" + o.attr("BYID") + "&BY=" + $(".OnBY").val(), success: function(msg) { if (msg.indexOf("[BYNOK]")>0) { o.html($(".OnBY").val()); } else { alert("发生错误: " + msg); o.html(old); } } }); }); }); }); 还有更多想法,等有空再增加上去 。比如修改时,数据处理有个时间,在等待的时间里,改变下鼠标样式为繁忙等 。 或更新后,重新装载数据,因为具体数据不同,只能具体应用 。也或者直接刷新页面 。 初学原创,请各位高手不吝赐教 。 Kas PS:关于ERic Poon 兄弟说何处用到,抓个图参考下吧 。 ![]() |