toString()一个会自动调用的方法


Posted in Javascript onFebruary 08, 2010

这一特性显然有助于你偷懒,当然也有利于实现一些特定的功能。为了说明这一特性,下面从一个实际开发案例说起。

如果在你的WEB项目中,有很多地方都需要输出像下面这样的一个列表HTML:

<ul> 
<li>JavaScript事件冒泡应用实例</li> 
<li>执行AJAX返回HTML片段中的JavaScript脚本</li> 
</ul>

很显然这是一个LI结构,也许你会想每次要输出这样结构的HTML,难道自己都要去拼这些LI标签吗?我能不能每次调用一个方法仅输入LI中间的文本内容,最终简单地得到一个完整的UL HTML结构呢。当然可以,程序的实现有N种方法,看看下面这种方法,这种方法显然简单而且科学:
function ulBuilder() 
{ 
var lis = ''; 
this.addLi = function(liText) 
{ 
lis += '<li>' + liText + '</li>'; 
}; this.toString = function() 
{ 
return '<ul>' + lis + '</ul>'; 
}; 
} 
var ulHtml = new ulBuilder(); 
ulHtml.addLi('JavaScript事件冒泡应用实例'); 
ulHtml.addLi('执行AJAX返回HTML片段中的JavaScript脚本'); 
alert(ulHtml);

在上面的代码中,我们定义了一个类叫ulBuilder,它有两个公开方法addLi、toString,addLi方法是添加一个包含内容的LI标签,而toString方法是生成最终需要的UL HTML。在这个类的实际使用过程中,你根本没有看到toString方法的调用,但是alert(ulHtml)却显示了完整的UL结构的HTML。

实际上alert()的时候,脚本解析器会自动检查alert变量或对象的toString方法并调用它。在上面的例子中,是我们重写了toString方法,而恰好这个方法会由程序自动调用执行。

话题扩展:
1、在一些面向对象的开发语言中,比如C#、JAVA都有构造函数,这个构造函数显然作为类的一个成员方法,要想执行里面的代码,并不需要我们手动去调用这个方法,这个方法内部定义的代码会在类实例化的时候自动执行。当然,为了让系统能自动执行一些特定的方法,往往程序架构会对这些方法的命名规则有规定,比如构造方法的名称要与类名相同。像上面的例子中,如果把this.toString改成this.toUL,那么要想得到正确的结果只能像这样调用了alert(ulHtml. toUL())。

2、由于toString方法可以被重写,有时候显的特别有用。看看下面的例子,试一下没有重写与重写后输出的结果有什么不同。这个例子显然很不健壮,比如对数组嵌套的情况没有作处理,而且实际意义也不大,只为让你知道可以这样做。

Array.prototype.toString = function() 
{ 
return '[\'' + this.join('\',\'') + '\']'; 
}; 
var companys = ['Adobe','Apple','Google','Intel','Microsoft','Oracle','IBM','SUN']; 
alert(companys);

下面再举一个例子,这个例子比上面例子实用些。正常情况下你alert(JSON)的时候,并不能看到JSON的真正结构,只弹出[object Object],试试下面的实现,也许这是你想要的结果。当然这个方法也是很不完善的,真要使用这样的功能,请到JSON官方站点去下载相关JS库吧:
var userInfo = 
{ 
"name": "Mike", 
"age": 23, 
"phone": "020-87654321", 
"toString": function() 
{ 
var objStr = ''; 
for (var key in this) 
{ 
if (typeof(this[key]) == 'string') 
objStr += '"' + key + '":"' + this[key] + '",'; 
} 
return '{' + objStr.replace(/,$/, '') + '}'; 
} 
} 
alert(userInfo);

作者:WebFlash
Javascript 相关文章推荐
JavaScript 权威指南(第四版) 读书笔记
Aug 11 Javascript
input 输入框内的输入事件详细分析
Mar 17 Javascript
为Extjs加加速(javascript加速)
Aug 19 Javascript
基于jquery的防止大图片撑破页面的实现代码(立即缩放)
Oct 24 Javascript
js的2种继承方式详解
Mar 04 Javascript
Javascript中innerHTML用法实例分析
Jan 12 Javascript
JavaScript判断是否为数组的3种方法及效率比较
Apr 01 Javascript
js实现文本框选中的方法
May 26 Javascript
基于JavaScript实现回到页面顶部动画代码
May 24 Javascript
JS批量替换内容中关键词为超链接
Feb 20 Javascript
koa源码中promise的解读
Nov 13 Javascript
Vue中使用better-scroll实现轮播图组件
Mar 07 Javascript
jQuery AJAX回调函数this指向问题
Feb 08 #Javascript
JavaScript Event学习第九章 鼠标事件
Feb 08 #Javascript
JavaScript 类似flash效果的立体图片浏览器
Feb 08 #Javascript
js 省地市级联选择
Feb 07 #Javascript
js 自定义的联动下拉框
Feb 07 #Javascript
比较搞笑的js陷阱题
Feb 07 #Javascript
javascript 鼠标拖动图标技术
Feb 07 #Javascript
You might like
很温暖很温暖的Lester Young
2021/03/03 冲泡冲煮
某大型网络公司应聘时的笔试题目附答案
2008/03/27 PHP
PHP SQLite类
2009/05/07 PHP
php include加载文件两种方式效率比较
2010/08/08 PHP
PHP版微信公众平台红包API
2015/04/02 PHP
分享PHP计算两个日期相差天数的代码
2015/12/23 PHP
Yii框架的布局文件实例分析
2019/09/04 PHP
JavaScript 事件对象的实现
2009/07/13 Javascript
基于JQuery的一句代码实现表格的简单筛选
2010/07/26 Javascript
javascript Array.prototype.slice的使用示例
2013/11/14 Javascript
jquery.validate.js插件使用经验记录
2014/07/02 Javascript
node.js使用require()函数加载模块
2014/11/26 Javascript
javascript实现图片跟随鼠标移动效果的方法
2015/05/13 Javascript
JS实现的车标图片提示效果代码
2015/10/10 Javascript
JavaScript中的 attribute 和 jQuery中的 attr 方法浅析
2017/01/04 Javascript
在javaScript中检测数据类型的几种方式小结
2017/03/04 Javascript
详解AngularJS 模块化
2017/06/14 Javascript
关于js的三种使用方式(行内js、内部js、外部js)的程序代码
2018/05/05 Javascript
jquery图片预览插件实现方法详解
2019/07/18 jQuery
vue中解决微信html5原生ios虚拟键返回不刷新问题
2020/10/20 Javascript
[08:04]TI4西雅图DOTA2前线报道 海涛探访各路人马
2014/07/09 DOTA
[01:19:35]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#2Fnatic VS OG第二局
2016/03/05 DOTA
[51:29]Alliance vs TNC 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/18 DOTA
用Python实现web端用户登录和注册功能的教程
2015/04/30 Python
使用python实现省市三级菜单效果
2016/01/20 Python
django 中的聚合函数,分组函数,F 查询,Q查询
2019/07/25 Python
如何基于windows实现python定时爬虫
2020/05/01 Python
让IE9以下版本的浏览器兼容HTML5的方法
2014/03/12 HTML / CSS
优秀班干部事迹材料
2014/01/26 职场文书
幼儿园毕业教师感言
2014/02/21 职场文书
农业局学习党的群众路线教育实践活动心得体会
2014/03/07 职场文书
卖房授权委托书样本
2014/10/05 职场文书
法制主题班会教案
2015/08/13 职场文书
Python字典的基础操作
2021/11/01 Python
「SHOW BY ROCK!!」“雫シークレットマインド”组合单曲MV公开
2022/03/21 日漫
Linux中各个目录的作用与内容
2022/06/28 Servers