javascript 對象 與 prototype 原型用法實(shí)例分析
本文實(shí)例講述了javascript 對象 與 prototype 原型用法。分享給大家供大家參考,具體如下:
我們做程序開發(fā)的,經(jīng)常面對的就是一個(gè)一個(gè)對象。那么在javascript中我們怎么去創(chuàng)建一個(gè)類以及一個(gè)對象呢?
<script type="text/javascript">
//創(chuàng)建一個(gè)Test對象
function Test(){
}
var test = new Test();
//創(chuàng)建一個(gè)對象
var obj = new Object();
//json 對象
var json1 = {};
</script>
類都有自己的屬性和方法,我們怎么去定義
<script type="text/javascript">
function Test(){
this.name = "譚勇";
this.age = 22;
this.getName = function(){
return this.name;
}
this.getAge = function(){
return this.age;
}
}
var test = new Test();
console.log(test); //查看一下日志
var obj = new Object();
obj.name = "譚勇";
obj.age = "22";
obj.getName = function(){
return this.name;
};
obj.getAge = function(){
return this.age;
};
console.log(obj); //查看下日志
var json1 = {};
json1["name"] = "譚勇";
json1["age"] = 22;
json1["getName"] = function(){
return this.name;
}
json1["getAge"] = function(){
return this.age;
}
console.log(json1); //查看下日志
</script>
構(gòu)造方法
<script type="text/javascript">
function Test2(name,age){
this.name = name;
this.age = age;
this.getName = function(){
return this.name;
}
this.getAge = function(){
return this.age;
}
}
var test2 = new Test2("譚勇",22);
console.log(test2); //查看下日志
</script>
行為有形參
<script type="text/javascript">
function Test3(){
this.demo = function(param_str){
return param_str;
}
}
var test3 = new Test3();
console.log(test3.demo("aaaaaaaaaaaaaaaaaaaa"));
</script>
繼承
<script type="text/javascript">
function parent(){
this.getStr = function(){
return "test str";
}
}
function son(){}
son.prototype = new parent();
var sona = new son();
console.log(sona.getStr());
</script>
拷貝繼承
<script type="text/javascript">
function extend(Child, Parent) {
var p = Parent.prototype;
var c = Child.prototype;
for (var i in p) {
c[i] = p[i];
}
}
function parent(){
}
parent.prototype.getStr=function(){
return "test str";
}
function son(){
}
extend(son,parent);
var sona = new son();
console.log(sona.getStr());
</script>
原型
原型是一個(gè)對象,其他對象可以通過它實(shí)現(xiàn)屬性繼承。
任何一個(gè)對象都可以成為原型么?
是
哪些對象有原型
所有的對象在默認(rèn)的情況下都有一個(gè)原型,因?yàn)樵捅旧硪彩菍ο?,所以每個(gè)原型自身又有一個(gè)原型(只有一種例外,默認(rèn)的對象原型在原型鏈的頂端。)
<script type="text/javacript">
var str = "譚勇";
String.prototype.getName = function(){
var strs = "";
for(var i=0;i<this.length;i++){
strs += this[i];
}
return strs;
}
console.log(str.getName());
console.log(str);
console.log(str[0]);
</script>
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
Mysql內(nèi)儲存JSON字符串根據(jù)條件進(jìn)行查詢
本文主要介紹了Mysql內(nèi)儲存JSON字符串根據(jù)條件進(jìn)行查詢,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02
IE8提示Invalid procedure call or argument 異常的解決方法
某臺機(jī)器上,訪問公司的好幾個(gè)產(chǎn)品網(wǎng)站,都拋出很多 Invalid procedure call or argument ,跟進(jìn)了下,情況最后簡化為2012-09-09
利用JS對iframe父子(內(nèi)外)頁面進(jìn)行操作的方法教程
這篇文章主要給大家介紹了利用JS對iframe父子(內(nèi)外)頁面進(jìn)行操作的方法教程,其中包括了怎么對iframe進(jìn)行操作、在iframe里面控制iframe外面的js代碼以及在父框架對子iframe進(jìn)行操作等,需要的朋友可以參考借鑒。2017-06-06
JS簡單操作select和dropdownlist實(shí)例
簡單實(shí)現(xiàn)節(jié)流函數(shù)和防抖函數(shù)過程解析
一文解決微信小程序button、input和image表單組件

