如果在你的WEB項目中,有很多地方都需要輸出像下面這樣的一個列表HTML: 復制代碼 代碼如下: <ul> <li>JavaS " /> 精品国产乱码久久久久久免费流畅,迅雷成人下载,99热在线播放

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

toString()一個會自動調用的方法

這一特性顯然有助于你偷懶,當然也有利于實現一些特定的功能。為了說明這一特性,下面從一個實際開發案例說起。

如果在你的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技術toString()一個會自動調用的方法,轉載需保留來源!

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

主站蜘蛛池模板: 日本漫画无彩翼漫画 | 夜夜穞狠狠穞 | 久久久免费热线精品频 | 超碰在线公开视频 | 91国在线视频 | 久久免费精彩视频 | 牛牛在线国产精品 | 国拍在线精品视频免费观看 | 久久免费精品视频 | 国产色综合久久无码有码 | 欧美日韩综合一区 | 男人插女人动态图 | 伊人久久99热这里只有精品 | 国产又黄又粗又爽又色的视频软件 | 国产GV天堂亚洲国产GV刚刚碰 | 九九热只有精品 | 欧美日韩一区二区三区四区 | 乱叫抽搐流白浆免费视频 | 羞羞影院午夜男女爽爽影院网站 | 成人精品视频网站 | 日本不卡三卡四卡 | 老女人与小伙子露脸对白 | 富婆大保健嗷嗷叫普通话对白 | 精品久久香蕉国产线看观看麻豆 | 亚洲AV美女成人网站P站 | 久久re6热在线视频精品 | 2021国产精品视频 | 好男人在线高清WWW免费观看 | 欧美丰满少妇久久无码精品 | 国产学生在线播放精品视频 | 国产h视频在线观看免费 | 久久久久亚洲日日精品 | 777久久人妻少妇嫩草AV | 免费看黄软件 | 青柠在线观看免费完整版 | 青草久久久 | 亚洲 欧美 综合 高清 在线 | 亚洲人成伊人成综合网久久久 | 国产精品JIZZ视频免费 | freehd另类xxxx喷水 | 中字幕视频在线永久在线观看免费 |