Javascript成立自定义对象 创造Object实例增加属性和办法

JavaScript
是一种很强的面向对象的语言,支持创建实例之后再添加属性和方法,虽然是小技巧,用的时候容易忘记,今天写了一个很小的例子,记录在这里,仅供参考。

Javascript 创建类并动态添加属性及方法的简单实现,javascript类并

JavaScript
是一种很强的面向对象的语言,支持创建实例之后再添加属性和方法,虽然是小技巧,用的时候容易忘记,今天写了一个很小的例子,记录在这里,仅供参考。

function MyClass() 
{  
  //This function is same as a constructer  
  alert("New Object Created");  
} 
//Creating Object  
var MyObject = new MyClass ();  
NewObject.prototype =  
{  
  //Adding Method named "MyMethod"  
  MyMethod: function(){alert("My Method");} ,  

  //Adding property named "MyProperty"  
  MyProperty: "My Property"  
} 

//Calling Method  
MyObject.MyMethod();  

//Assigning Property  
MyObject.MyProperty = "My Property Value changed"; 

一个小例子,高手勿喷,欢迎留言交流。

以上就是小编为大家带来的Javascript
创建类并动态添加属性及方法的简单实现全部内容了,希望大家多多支持帮客之家~

创建类并动态添加属性及方法的简单实现,javascript类并 JavaScript
是一种很强的面向对象的语言,支持创建实例之后再添加属性和方…

如下所示:

如下所示:

在注册信息的时候,常常需要通过下拉菜单让用户选择,而且希望用户在第一个下拉框做的选择,影响第二个下拉框的内容。有时候,如果第一个下拉框不作出选择,第二个下拉框根本不会页面上显示,为了给用户呈现一个更清晰的页面。

function MyClass() 
{  
  //This function is same as a constructer  
  alert("New Object Created");  
} 
//Creating Object  
var MyObject = new MyClass ();  
NewObject.prototype =  
{  
  //Adding Method named "MyMethod"  
  MyMethod: function(){alert("My Method");} ,  

  //Adding property named "MyProperty"  
  MyProperty: "My Property"  
} 

//Calling Method  
MyObject.MyMethod();  

//Assigning Property  
MyObject.MyProperty = "My Property Value changed"; 

复制代码 代码如下:

复制代码 代码如下:

 
先来看看效果:

一个小例子,高手勿喷,欢迎留言交流。

var person = new Object();
person.name = “Nicholas”;
person.age = “29”
person.job = “Software Engineer”;

var person = new Object();
person.name = “Nicholas”;
person.age = “29”
person.job = “Software Engineer”;

 图片 1

以上就是小编为大家带来的Javascript
创建类并动态添加属性及方法的简单实现全部内容了,希望大家多多支持脚本之家~

person.sayName = function () {
alert(this.name);
};

person.sayName = function () {
alert(this.name);
};

 

您可能感兴趣的文章:

  • Javascript使用function创建类的两种方法(推荐)
  • JS创建类和对象的两种不同方式
  • JavaScript中创建类/对象的几种方法总结
  • JavaScript创建类/对象的几种方式概述及实例
  • javascript最常用与实用的创建类的代码
  • 利用MS
    AJAX注册Javascript命名空间并创建类
  • 讨论javascript(一)工厂方式
    js面象对象的定义方法
  • javascript工厂方式定义对象
  • JavaScript中使用构造器创建对象无需new的情况说明
  • JavaScript设计模式之工厂模式和构造器模式
  • javascript
    混合的构造函数和原型方式,动态原型方式
  • JS常见创建类的方法小结【工厂方式,构造器方式,原型方式,联合方式等】

person.sayName();上面的例子创建了一个名为person的对象,并为它添加了三个属性(name、age和job)和一个方法(sayName())。其中,sayName()方法用于显示this.name()的值。早期的JavaScript开发人员经常使用这个模式创建新对象。但这种方式有个明显的缺点:使用同一个接口创建很多对象,会产生大量的重复代码。为了解决这个问题,人们开始使用工厂模式的一种变体。

person.sayName();上面的例子创建了一个名为person的对象,并为它添加了三个属性(name、age和job)和一个方法(sayName())。其中,sayName()方法用于显示this.name()的值。早期的JavaScript开发人员经常使用这个模式创建新对象。但这种方式有个明显的缺点:使用同一个接口创建很多对象,会产生大量的重复代码。为了解决这个问题,人们开始使用工厂模式的一种变体。

Html源码:
[html]
1. <!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN”
“; 
2. <html xmlns=”; 
3. <head> 
4.  
5. <meta http-equiv=”Content-Type” content=”text/html; charset=utf-8″
/> 
6. <title>动态改变菜单</title> 
7. <script type=”text/javascript”
src=”jquery.js”></script> 
8. <script type=”text/javascript”
src=”SelectMenu.js”></script> 
9.  
10. </head> 
11.  
12. <body> 
13. <form action=”#”> 
14. <br/> 
15. <br/> 
16. <br/> 
17.  
18.     <div class=”Address”> 
19.         
20.         <span class=”Province”>Province: 
21.             <select> 
22.                 <option value=”” selected=”selected”>Please
Choose Province</option> 
23.                 <option value=”HeBei”>HeBei</option> 
24.                 <option
value=”ShanDong”>ShanDong</option> 
25.             </select>  
26.         </span> 
27.     
28.         <span class=”City” style=”display:none”>City: 
29.             <select> 
30.             </select> 
31.         </span> 
32.         <span class=”Area” style=”display:none”>Area: 
33.             <select> 
34.             </select> 
35.         </span> 
36.         <br/> 
37.          <br/> 
38.         <span class=”AddressSelect” style=”display:none”> 
39.         </span> 
40.     </div> 
41.  
42. </form> 
43. </body> 
44. </html> 
 
Javascript源码
[javascript]
1. $(document).ready(function () { 
2.      
3.     //找到三个下拉框  
4.     var ProvinceSelect = $(“.Province”).children(“select”); 
5.     var CitySelect = $(“.City”).children(“select”); 
6.     var AreaSelect = $(“.Area”).children(“select”); 
7.     var AddressSelect=$(“.AddressSelect”); 
8.      
9.     //给第二个下拉框注册事件  
10.     ProvinceSelect.change(function () { 
11.                                  
12.         //1、获取当前下拉框的值  
13.          var ProvinceValue = $(this).val(); 
14.        
//1.1只要第一个下拉框内容有变化,第三个下拉框就要隐藏起来  
15.         AreaSelect.parent().hide(); 
16.         AddressSelect.hide(); 
17.         AddressSelect.html(“”); 
18.         //2、如果值不为空,则显示城市下拉框  
19.          if (ProvinceValue != “”) { 
20.                    CitySelect.html(“”); 
21.                    $(“<option value=”>Please Choose
City</option>”).appendTo(CitySelect); 
22.                     switch(ProvinceValue) 
23.                        { 
24.                        
//实际项目中,这个城市数组肯定是在服务器获取的,这里为了简便,我就直接自定义了一个数组  
25.                        
//如果追求完美,这里还可以加一道缓存,防止重复获取  
26.                        case “HeBei”: 
27.                             var
CityOfHeBei=[“ShiJiaZhuang”,”CangZhou”,”LangFang”];  
28.                             for(var
i=0;i<CityOfHeBei.length;i++){ 
29.                                 $(“<option
value='”+CityOfHeBei[i]+”‘>”+CityOfHeBei[i]+”</option>”).appendTo(CitySelect); 
30.                             } 
31.                              break; 
32.                        case “ShanDong”: 
33.                             var
CityOfShanDon=[“JiNan”,”DeZhou”,”QingDao”];      
34.                             for(var
i=0;i<CityOfShanDon.length;i++){ 
35.                                 $(“<option
value='”+CityOfShanDon[i]+”‘>”+CityOfShanDon[i]+”</option>”).appendTo(CitySelect); 
36.                             } 
37.                             break; 
38.                      
39.                        } 
40.                  CitySelect.parent().show();    
41.         } else { 
42.             CitySelect.parent().hide(); 
43.         } 
44.  
45.     }); 
46.  
47.   
48.  
49.     //给第二个下拉框注册事件  
50.      CitySelect.change(function () { 
51.              
52.             var CityValue = $(this).val();       
53.             AddressSelect.hide(); 
54.             AreaSelect.parent().hide();  
55.             AddressSelect.html(“”); 
56.              if (CityValue != “”) { 
57.                    AreaSelect.html(“”); 
58.                    $(“<option value=”>Please Choose
Area</option>”).appendTo(AreaSelect); 
59.                     switch(CityValue) 
60.                        { 
61.                       
//实际项目中,这个区数组肯定是在服务器获取的,这里为了简便,我就直接自定义了一个数组  
62.                       
//如果追求完美,这里还可以加一道缓存,防止重复获取  
63.                        case “ShiJiaZhuang”: 
64.                             var
AreaOfCity=[“GaoXinQu”,”KaiFaQu”,”XinHuaQu”];    
65.                             for(var
i=0;i<AreaOfCity.length;i++){ 
66.                                 $(“<option
value='”+AreaOfCity[i]+”‘>”+AreaOfCity[i]+”</option>”).appendTo(AreaSelect); 
67.                             } 
68.                              break; 
69.                        case “CangZhou”: 
70.                             var
AreaOfCity=[“XinHuaQu”,”YunHeQu”];       
71.                             for(var
i=0;i<AreaOfCity.length;i++){ 
72.                                 $(“<option
value='”+AreaOfCity[i]+”‘>”+AreaOfCity[i]+”</option>”).appendTo(AreaSelect); 
73.                             } 
74.                             break; 
75.                        case “LangFang”: 
76.                             var
AreaOfCity=[“AnCiQu”,”GuangYangQu”]; 
77.                             for(var
i=0;i<AreaOfCity.length;i++){ 
78.                                 $(“<option
value='”+AreaOfCity[i]+”‘>”+AreaOfCity[i]+”</option>”).appendTo(AreaSelect); 
79.                             } 
80.                             break; 
81.                        case “QingDao”: 
82.                             var
AreaOfCity=[“GaoXinQu”,”KaiFaQu”,”XinHuaQu”];    
83.                             for(var
i=0;i<AreaOfCity.length;i++){ 
84.                                 $(“<option
value='”+AreaOfCity[i]+”‘>”+AreaOfCity[i]+”</option>”).appendTo(AreaSelect); 
85.                             } 
86.                              break; 
87.                        case “DeZhou”: 
88.                             var
AreaOfCity=[“XinHuaQu”,”YunHeQu”];       
89.                             for(var
i=0;i<AreaOfCity.length;i++){ 
90.                                 $(“<option
value='”+AreaOfCity[i]+”‘>”+AreaOfCity[i]+”</option>”).appendTo(AreaSelect); 
91.                             } 
92.                             break; 
93.                        case “JiNan”: 
94.                             var
AreaOfCity=[“AnCiQu”,”GuangYangQu”]; 
95.                             for(var
i=0;i<AreaOfCity.length;i++){ 
96.                                 $(“<option
value='”+AreaOfCity[i]+”‘>”+AreaOfCity[i]+”</option>”).appendTo(AreaSelect); 
97.                             } 
98.                             break; 
99.                        } 
100.                      AreaSelect.parent().show();  
101.                  
102.                       
103.              } else { 
104.                      AreaSelect.parent().hide(); 
105.             } 
106.  
107.     }); 
108.  
109.     AreaSelect.change(function(){ 
110.             var AreaValue=$(this).val(); 
111.             AddressSelect.html(“”); 
112.             if (AreaValue!=””){ 
113.                 $(“<span>The Address Is –Province:
“+ProvinceSelect.val()+”  City: “+CitySelect.val()+”  Area:
“+AreaSelect.val()+”</span>”).appendTo(AddressSelect); 
114.             AddressSelect.show(); 
115.             //alert(“The Address Is  Province:
“+ProvinceSelect.val()+”  City: “+CitySelect.val()+”  Area:
“+AreaSelect.val());  
116.                 }                   
117.      }) 
118.  
119. }); 
 
这里还引用了Jquery,貌似实现这个效果,用不用都无所谓,最近为了熟悉Jquery的用法,所以就加上了。

复制代码 代码如下: var person = new
Object(); person.name = “Nicholas”; person.age = “29” person.job =
“Software Engineer”; person.sayName = function () { al…

您可能感兴趣的文章:

  • Javascript
    中创建自定义对象的方法汇总
  • jQuery asp.net
    用json格式返回自定义对象
  • JavaScript 类的定义和引用 JavaScript高级培训
    自定义对象
  • JS自定义对象实现Java中Map对象功能的方法
  • 构造函数+原型模式构造js自定义对象(最通用)
  • javascript中自定义对象的属性方法分享
  • JavaScript
    三种创建对象的方法
  • JS
    创建对象(常见的几种方法)
  • js创建对象的几种常用方式小结(推荐)
  • JavaScript实现创建自定义对象的常用方式总结

 摘自 贾琳的专栏
 

相关文章