Heim >Web-Frontend >js-Tutorial >js defineSetter -给js的 "class"自动增加一个set的属性(方法)_javascript技巧

js defineSetter -给js的 "class"自动增加一个set的属性(方法)_javascript技巧

WBOY
WBOYOriginal
2016-05-16 19:12:511110Durchsuche

写注释不是我的强项,有什么问题请在评论中写出来:D

写一个JS class时,如


[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]

为了容易理解代码,以及更好的区分public和private的变量,我通常用set...方法(...为某(些)成员变量)来赋值给类的成员。这些set方法当然就是public的。还有一点就是使代码能够更规范一些。

然而问题就出在这里,如果以上代码不考虑验证有效性(或者只验证简单的有效性),那我们就会多出很多的代码,试想一个类有20个成员(属性),那么我们就得加20个set...方法,实在多余,因此,要想办法来解决这个问题。

回忆在Mozilla中,有__defineSetter__和__defineGetter__的方法来给DOM增加成员,给开发人员带来很多方便。我们也来仿一个js版的__defineSetter。

简单的思路:
利用JS动态给对象增加方法(或属性)
但类中方法不必再添加set...此类方法。
非[a-z]区间的属性也不再添加set...此类方法。

写出实现代码

基本实现了_defineSetter,而我们要一个个的defineSetter岂不是太麻烦了。既然已经实现了原型,那么用原型来动态绑定到Function对象上,一行代码就解决了set..方法了。
Function.prototype.defineAllSetter = function (hdle) {

  for (var i in this.prototype)
  _defineSetter.apply(this, [this,i,hdle]);

  return this;

};

接下来就是再绑定一个defineSetter给Function对象。

Function.prototype.defineSetter = function (p, hdle) {

  return _defineSetter.apply(this, 
  [this].concat(Array.prototype.slice.call(arguments,0)));

};

OK!基本完成想要的功能。try it...

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
本例DEMO及全部代码:
http://www.never-online.net/code/js/defineSetter/

当然,我们还可以加入验证~,具体的代码我就不再多写了,呵呵,已经实现了,有兴趣的朋友也试着玩一下:D。 
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn