javascript中的一些注意事項(xiàng) 更新中
更新時(shí)間:2010年12月06日 21:42:10 作者:
記錄一下這些內(nèi)容只是以后查閱起來方便,作為自己知識(shí)積累的記錄。其中有很多是參考網(wǎng)絡(luò)上的資源,不再一一寫出出處,還請(qǐng)?jiān)髡咭娬彙?/div>
一.prototype原型對(duì)象,需要注意的原則是:
(1). 使用原型可以大量減少每個(gè)對(duì)象對(duì)內(nèi)存的需求量,因?yàn)閷?duì)象可以繼承許多屬性。
(2). 即使屬性在對(duì)象被創(chuàng)建之后才被添加至原型中,對(duì)象也能夠繼承這些屬性。
示例代碼:
<script type="text/javascript">
function print(msg)
{
document.write(msg,'<br/>');
}
function printhr()
{
document.write('<hr/>');
}
print("prototype屬性:<br/>"+
"1. 使用原型可以大量減少每個(gè)對(duì)象對(duì)內(nèi)存的需求量,因?yàn)閷?duì)象可以繼承許多屬性。<br/>"+
"2. 即使屬性在對(duì)象被創(chuàng)建之后才被添加至原型中,對(duì)象也能夠繼承這些屬性。");
printhr();
function User(name)
{
this.name=name;
}
var zhang = new User('老張');
zhang.favchannel ='hello';
User.prototype.favchannel='CCTV';
Object.prototype.qq ='569723660';
print(zhang.favchannel);
print(zhang.qq);
</script>
運(yùn)行結(jié)果為:
prototype屬性:
1. 使用原型可以大量減少每個(gè)對(duì)象對(duì)內(nèi)存的需求量,因?yàn)閷?duì)象可以繼承許多屬性。
2. 即使屬性在對(duì)象被創(chuàng)建之后才被添加至原型中,對(duì)象也能夠繼承這些屬性。
二.setTimeout和setInterval 兩個(gè)函數(shù)都定義在window對(duì)象中。setTimeout(fun_name,time_minisec)作用是在time時(shí)間后運(yùn)行fun_name函數(shù)一次;setInterval(fun_name,time_minisec)作用是每隔time_sec時(shí)間都去運(yùn)行fun_name函數(shù)。
示例代碼如下:
<html>
<head></head>
<body>
<div id="show"></div>
<input type="button" value='' id='btntime'></input>
<script type='text/javascript'>
function print(msg)
{
document.write(msg,'<br/>');
}
var changetime = function()
{
var d=new Date();
var h=d.getHours();
var m=d.getMinutes();
var sec=d.getSeconds();
var ampm=(h>=12)?'PM':'AM';
if(h>12) h-=12;
if(h==0)h=12;
if(m<10) m='0'+m;
var t=h+':'+m+':'+sec+" "+ampm;
var button = document.getElementById('btntime');
button.value = "setInterval:"+t;
}
changetime();
setInterval("changetime()",1000);
function time_setTimeOut()
{
var d=new Date();
var h=d.getHours();
var m=d.getMinutes();
var sec=d.getSeconds();
var ampm=(h>=12)?'PM':'AM';
if(h>12) h-=12;
if(h==0)h=12;
if(m<10) m='0'+m;
var t=h+':'+m+':'+sec+" "+ampm;
document.getElementById('show').innerHTML='setTimeout:'+t;
setTimeout('time_setTimeOut()',1000);
}
time_setTimeOut();
</script>
</body>
</html>
三.本地對(duì)象,內(nèi)置對(duì)象和宿主對(duì)象
1.本地對(duì)象包含的內(nèi)容有 Object、Function、Array、String、Boolean、Number、Date、RegExp、Error、EvalError、RangeError、ReferenceError、SyntaxError、TypeError、URIError 都是一些 ECMA-262 定義的引用類型。
2.內(nèi)置對(duì)象:由 ECMAScript 實(shí)現(xiàn)提供的、獨(dú)立于宿主環(huán)境的所有對(duì)象,在 ECMAScript 程序開始執(zhí)行時(shí)出現(xiàn)(ECMA-262定義), 內(nèi)置對(duì)象只有兩個(gè)Global 和 Math ,它們都是本地對(duì)象。內(nèi)置對(duì)象就是一種特殊的本地對(duì)象。
3.宿主對(duì)象:所有非本地對(duì)象都是宿主對(duì)象(host object),即由 ECMAScript 實(shí)現(xiàn)的宿主環(huán)境提供的對(duì)象。
總之,本地對(duì)象,就是那些官方定義好了的對(duì)象。內(nèi)置對(duì)象是本地對(duì)象的一種,其只包含Global對(duì)象和Math對(duì)象。而宿主對(duì)象則是那些官方未定義,你自己構(gòu)建的對(duì)象加上DOM和BOM對(duì)象組成的。
四.Array.prototype.slice.call(_array,begin[,end]) 的使用相當(dāng)于_array.slice(begin[,end]),不過Array.prototype.slice.call的效率要遠(yuǎn)遠(yuǎn)高過第二種用法。
示例:
function p(msg)
{
document.write(msg,'<br/>');
}
p(Array.prototype.slice.call([1,2,3,4],2));
p([1,2,3,4].slice(2));
運(yùn)行結(jié)果:
3,4
3,4
(注:記錄一下這些內(nèi)容只是以后查閱起來方便,作為自己知識(shí)積累的記錄。其中有很多是參考網(wǎng)絡(luò)上的資源,不再一一寫出出處,還請(qǐng)?jiān)髡咭娬彙?
(1). 使用原型可以大量減少每個(gè)對(duì)象對(duì)內(nèi)存的需求量,因?yàn)閷?duì)象可以繼承許多屬性。
(2). 即使屬性在對(duì)象被創(chuàng)建之后才被添加至原型中,對(duì)象也能夠繼承這些屬性。
示例代碼:
復(fù)制代碼 代碼如下:
<script type="text/javascript">
function print(msg)
{
document.write(msg,'<br/>');
}
function printhr()
{
document.write('<hr/>');
}
print("prototype屬性:<br/>"+
"1. 使用原型可以大量減少每個(gè)對(duì)象對(duì)內(nèi)存的需求量,因?yàn)閷?duì)象可以繼承許多屬性。<br/>"+
"2. 即使屬性在對(duì)象被創(chuàng)建之后才被添加至原型中,對(duì)象也能夠繼承這些屬性。");
printhr();
function User(name)
{
this.name=name;
}
var zhang = new User('老張');
zhang.favchannel ='hello';
User.prototype.favchannel='CCTV';
Object.prototype.qq ='569723660';
print(zhang.favchannel);
print(zhang.qq);
</script>
運(yùn)行結(jié)果為:
prototype屬性:
1. 使用原型可以大量減少每個(gè)對(duì)象對(duì)內(nèi)存的需求量,因?yàn)閷?duì)象可以繼承許多屬性。
2. 即使屬性在對(duì)象被創(chuàng)建之后才被添加至原型中,對(duì)象也能夠繼承這些屬性。
二.setTimeout和setInterval 兩個(gè)函數(shù)都定義在window對(duì)象中。setTimeout(fun_name,time_minisec)作用是在time時(shí)間后運(yùn)行fun_name函數(shù)一次;setInterval(fun_name,time_minisec)作用是每隔time_sec時(shí)間都去運(yùn)行fun_name函數(shù)。
示例代碼如下:
復(fù)制代碼 代碼如下:
<html>
<head></head>
<body>
<div id="show"></div>
<input type="button" value='' id='btntime'></input>
<script type='text/javascript'>
function print(msg)
{
document.write(msg,'<br/>');
}
var changetime = function()
{
var d=new Date();
var h=d.getHours();
var m=d.getMinutes();
var sec=d.getSeconds();
var ampm=(h>=12)?'PM':'AM';
if(h>12) h-=12;
if(h==0)h=12;
if(m<10) m='0'+m;
var t=h+':'+m+':'+sec+" "+ampm;
var button = document.getElementById('btntime');
button.value = "setInterval:"+t;
}
changetime();
setInterval("changetime()",1000);
function time_setTimeOut()
{
var d=new Date();
var h=d.getHours();
var m=d.getMinutes();
var sec=d.getSeconds();
var ampm=(h>=12)?'PM':'AM';
if(h>12) h-=12;
if(h==0)h=12;
if(m<10) m='0'+m;
var t=h+':'+m+':'+sec+" "+ampm;
document.getElementById('show').innerHTML='setTimeout:'+t;
setTimeout('time_setTimeOut()',1000);
}
time_setTimeOut();
</script>
</body>
</html>
三.本地對(duì)象,內(nèi)置對(duì)象和宿主對(duì)象
1.本地對(duì)象包含的內(nèi)容有 Object、Function、Array、String、Boolean、Number、Date、RegExp、Error、EvalError、RangeError、ReferenceError、SyntaxError、TypeError、URIError 都是一些 ECMA-262 定義的引用類型。
2.內(nèi)置對(duì)象:由 ECMAScript 實(shí)現(xiàn)提供的、獨(dú)立于宿主環(huán)境的所有對(duì)象,在 ECMAScript 程序開始執(zhí)行時(shí)出現(xiàn)(ECMA-262定義), 內(nèi)置對(duì)象只有兩個(gè)Global 和 Math ,它們都是本地對(duì)象。內(nèi)置對(duì)象就是一種特殊的本地對(duì)象。
3.宿主對(duì)象:所有非本地對(duì)象都是宿主對(duì)象(host object),即由 ECMAScript 實(shí)現(xiàn)的宿主環(huán)境提供的對(duì)象。
總之,本地對(duì)象,就是那些官方定義好了的對(duì)象。內(nèi)置對(duì)象是本地對(duì)象的一種,其只包含Global對(duì)象和Math對(duì)象。而宿主對(duì)象則是那些官方未定義,你自己構(gòu)建的對(duì)象加上DOM和BOM對(duì)象組成的。
四.Array.prototype.slice.call(_array,begin[,end]) 的使用相當(dāng)于_array.slice(begin[,end]),不過Array.prototype.slice.call的效率要遠(yuǎn)遠(yuǎn)高過第二種用法。
示例:
function p(msg)
{
document.write(msg,'<br/>');
}
p(Array.prototype.slice.call([1,2,3,4],2));
p([1,2,3,4].slice(2));
運(yùn)行結(jié)果:
3,4
3,4
(注:記錄一下這些內(nèi)容只是以后查閱起來方便,作為自己知識(shí)積累的記錄。其中有很多是參考網(wǎng)絡(luò)上的資源,不再一一寫出出處,還請(qǐng)?jiān)髡咭娬彙?
相關(guān)文章
webpack打包后直接訪問頁面圖片路徑錯(cuò)誤的解決方法
這篇文章主要給大家介紹了在webpack打包后直接訪問頁面圖片路徑錯(cuò)誤的解決方法,文中介紹的非常詳細(xì),對(duì)遇到這個(gè)問題的朋友們具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-06-06js實(shí)現(xiàn)iPhone界面風(fēng)格的單選框和復(fù)選框按鈕實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)iPhone界面風(fēng)格的單選框和復(fù)選框按鈕,涉及javascript動(dòng)態(tài)操作頁面元素樣式的相關(guān)技巧,非常美觀大方,需要的朋友可以參考下2015-08-08JS實(shí)現(xiàn)表單全選以及取消全選實(shí)例
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)表單全選以及取消全選實(shí)例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03swiper 解決動(dòng)態(tài)加載數(shù)據(jù)滑動(dòng)失效的問題
下面小編就為大家分享一篇swiper 解決動(dòng)態(tài)加載數(shù)據(jù)滑動(dòng)失效的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-02-02JavaScript編程的10個(gè)實(shí)用小技巧
盡管我使用Javascript來做開發(fā)有很多年了,但它常有一些讓我很驚訝的小特性。對(duì)于我來說,Javascript是需要持續(xù)不斷的學(xué)習(xí)的。2014-04-04微信小程序?qū)崿F(xiàn)topBar底部選擇欄效果
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)topBar底部選擇欄效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07