寫一個JS class時,如 [Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]為了容易理解代碼,以及更好的區分public和private的變量,我通常用set...方法(...為某(些)成員 " /> 欧美亚洲成人网,亚洲日本视频,国产精品激情

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

js defineSetter -給js的 "class"自動增加一個set的屬性(方法)

寫注釋不是我的強項,有什么問題請在評論中寫出來: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...此類方法。

寫出實現代碼

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
基本實現了_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。 

JavaScript技術js defineSetter -給js的 "class"自動增加一個set的屬性(方法),轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 通江县| 大同县| 蓝山县| 东阳市| 界首市| 岱山县| 扶绥县| 佛冈县| 合川市| 日土县| 吴忠市| 昆明市| 闻喜县| 托里县| 旌德县| 承德市| 宝丰县| 梁平县| 古蔺县| 囊谦县| 西宁市| 孙吴县| 泰安市| 嘉定区| 育儿| 盐山县| 富平县| 汨罗市| 休宁县| 江华| 峡江县| 四平市| 仁布县| 象州县| 大荔县| 固安县| 长丰县| 新干县| 德清县| 深州市| 阿合奇县|