jQuery重写属性教程

jQuery是一个款非常优秀的类库,它给我们解决了很多的客户端编程,但是任何东西都不是万能的,当它不能满足我们的需求时我们就需要对它进行重写,同时也不要影响其原有的功能或者修改其原有的功能;比如我现在的web应用程序大多数时候的数据交互都是通过Ajax来完成的,这样就可以将一些隐藏字段的数据保存在HTML标签的属性中,使HTML标签的代码量减少,如:ID,Timestamp等等,这些不需要用户输入但又不得不提交的字段,通过表单提交的做法是

1<input name="ID" value="343" type="hidden" />

把ID的值保存在一个隐藏标签中,然后随表单提交。

代码如下所示:

1<div>
2<label data-field="id" data-property="data-id" data-id="343">First Name</label><input type="text" data-field="FirstName" />
3</div>

注意蓝色的部分这个属性名称请不要太在意,您完全可以取一些更简洁名字,现在我们来重写jQuery的val方法来读取和设置data-id的值,给$.prototype.val重新定义一个函数,以闭包的形式将基类函数传入,以便在新函数中调用它,看下面这段代码:

01<script>
02    $.prototype.val = function (base) {
03      return function () {
04        var s = this, a = "data-property", p = s.attr(a), isset = arguments.length > 0, v = isset ? arguments[0] : null;
05         //这里调用基类方法,当然基类方法在何时调用或者是否要调用取决于您的业务逻辑,在这里我们是要调用的,因为要保持它原有的功能。
06        if (isset&&typeof(base)=="function") { base.call(s, v); } else { v = base.call(s); }
07        if (p) {
08          if (isset) { s.attr(p, v); return s }
09          else { return s.attr(p) }
10        }
11        else {
12          if (!s.is(":input"))
13          { if (isset) { s.text(v); return s; } else { return s.text(); } }
14          else { return isset ? s : v; }
15        }
16          
17      }
18      //在这里传入基类方法
19    }($.prototype.val);
20</script>

 这个重写了之后,当在标签中指定了data-property属性时,jQuery对象调用val() 等同于调用attr("data-property"),但没有指定data-property也就是默认情况下,如果是非表单元素则是val()等同于text(),如果是表单元素则保持原来的功能也就是读写value属性的值,这样就可以通过这种方式:$("[data-field='id']").val(345)和$("[data-field='id']").val() 读取或者设置它的值了,“data-field” 这个属性将会映射到服务器上对应类型的字段中,关于重写JavaScript中的jQuery的方法就到这里了,其他方法的重写是异曲同工的,大家可以举一反三的思考。

全部代码如下:

01<!DOCTYPE html>
02<html xmlns="http://www.zjjsepc.com/">
03<head>
04<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
05  <title>在JavaScript中重写对象的方法</title>
06  <script src="Scripts/jquery-1.8.2.min.js"></script>
07  <script src="Scripts/jquery-ui-1.8.24.min.js"></script>
08  <script>
09    $.prototype.val = function (base) {
10      return function () {
11        var s = this, a = "data-property", p = s.attr(a), isset = arguments.length > 0, v = isset ? arguments[0] : null;
12        if (isset&&typeof(base)=="function") { base.call(s, v); } else { v = base.call(s); }
13        if (p) {
14          if (isset) { s.attr(p, v); return s }
15          else { return s.attr(p) }
16        }
17        else {
18          if (!s.is(":input"))
19          { if (isset) { s.text(v); return s; } else { return s.text(); } }
20          else { return isset ? s : v; }
21        }
22      }
23    }($.prototype.val);
24  </script>
25</head>
26<body>
27  <span id="lbl">Hello world!</span>
28  <input type="text" id="txt" value="hello world" />
29  <input type="checkbox" value="哈哈哈。。。" />
30</body>
31</html>

希望本文所述对大家的web前段设计有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值