利用javascript轻松实现asp.net webcontrol中的render方法
来源:广州中睿信息技术有限公司官网
发布时间:2012/10/21 23:25:16 编辑:admin 阅读 322
在asp.net中的webcontrol开发的时候采用render方法来呈现控件。在javascript中,对于一些html代码的拼接大多数情况下采用字符串相加的方式来处理,这样做有以下弊端:1.可

在asp.net中的webcontrol开发的时候采用render方法来呈现控件。在javascript中,对于一些html代码的拼接大多数情况下采用字符串相加的方式来处理,这样做有以下弊端:

1.可读性差,易出错,出错后不易发现。

2.在javascript最小化的时候,长长的字符串不能最下化。

于是在项目中我实现了累死render的方法来处理html代码的拼接。

  StringBuilder = function () {    var self = this,     strs = [];      self.append = function (str) {     strs.push(str);    };      self.toString = function () {     return strs.join("");    };      self.dispose = function () {     strs = null;    };   },     TextElement = function (text) {    this.text = text;      this.render = function () {     return this.text;    };   },     HtmlElement = function (tagName, innerText, attributes) {    var self = this,     halfTags = { br: true, img: true, hr: true, input: true };      self.tagName = tagName || "div";    self.attributes = attributes || {};    self.innerText = innerText || "";    self.children = [];      if ($.isPlainObject(innerText)) {     self.innerText = "";     self.attributes = innerText;    }      self._isShortTag = false;      if (halfTags[self.tagName] === true) {     self._isShortTag = true;    }      self.render = function () {     var sb = new StringBuilder(),      html = "";       sb.append(self._renderBeginTag(self.tagName, self.attributes));     if (self.innerText !== "") {      sb.append(self.innerText);     }       if (self.children.length > 0) {      $.each(self.children, function (index, ele) {       sb.append(ele.render());      });     }       sb.append(self._renderEndTag(self.tagName));     html = sb.toString();     sb.dispose();       return html;    };      self.add = function (ele) {     this.children.push(ele);    };      self._renderBeginTag = function (tagName, attributes) {     var sb = new StringBuilder(),      strRet = "";     sb.append("<");     sb.append(tagName);     $.each(attributes, function (key, value) {      sb.append(" ");      sb.append(key);      sb.append("=");      sb.append("\"");      sb.append(value.toString());      sb.append("\"");     });       if (this._isShortTag) {      sb.append(" ");     } else {      sb.append(">");     }       strRet = sb.toString();     sb.dispose();       return strRet;    };      self._renderEndTag = function (tagName) {     var sb = new StringBuilder(),      strRet = "";       if (this._isShortTag) {      sb.append("/>");     } else {      sb.append("</");      sb.append(tagName);      sb.append(">");     }     strRet = sb.toString();     sb.dispose();     return strRet;    };   };  

最上面上在javascript中实现了一个stringBuilder类。处理字符串拼接的。用户用的时候采用下面的方法来调用HtmlElement这个类

  var div = new HtmlElement("div", {class:"divcss"});  var innertextbox = new HtmlElement("input", {type:"text"});  div.add(innertextbox);  var str =  div.render();  

str得到的结果是

  <div class="divcss">  <input type="text" />  </div>  

在使用的时候可以将创建textbox以及一些常用的html element封装成方法,这样就能提高代码的重用性,减少代码体积,也便于维护。

联系我们CONTACT 扫一扫
愿景:成为最专业的软件研发服务领航者
中睿信息技术有限公司 广州•深圳 Tel:020-38931912 务实 Pragmatic
广州:广州市天河区翰景路1号金星大厦18层中睿信息 Fax:020-38931912 专业 Professional
深圳:深圳市福田区车公庙有色金属大厦509~510 Tel:0755-25855012 诚信 Integrity
所有权声明:PMI, PMP, Project Management Professional, PMI-ACP, PMI-PBA和PMBOK是项目管理协会(Project Management Institute, Inc.)的注册标志。
版权所有:广州中睿信息技术有限公司 粤ICP备13082838号-2