JS的高级编程

2 篇文章 0 订阅
【FROM:http://www.blogjava.net/xzclog/archive/2011/07/09/353978.html】


研究发现:属性(变量)可分为三类(对象属性、全局变量和局部变量)

  1. 对象属性:声明时以“this.”开头,只能被“类的实例”即对象所调用,不能被“类内部(对外不对内)”调用;
  2. 全局变量:声明时直接以变量名开头,可以任意调用(对内对外);
  3. 局部变量:只能被“类内部(对内不对外)”调用。

JS函数的声明与访问原理

//类   
var testClass = function(){   
  //对象属性(对外不对内,类调用)   
  this.age ="25";   
  //全局变量(对内对外)   
  name="jack";   
  //局部变量(对内不对外)
  var address = "beijing";
     
  //全局函数(对内对外)   
  add = function(a,b){   
    //可访问:全局变量和局部变量   
    multiply(a,b);   
    return a+b;   
  }   
  //实例函数(由类的对象调用)   
  this.minus = function(a,b){   
    //可以访问:对象属性、全局变量和局部变量   
    return a-b;   
  }   
  //局部函数(内部直接调用)   
  var multiply = function(a,b){   
    //只能访问:全局变量和局部变量   
    return a*b;   
  }   
}   
  
  
//类函数(由类名直接调用)   
testClass.talk= function(){   
  //只能访问:全局变量和全局函数   
  this.what = function(){   
    alert("What can we talk about?");   
    about();   
  }   
     
  var about = function(){   
    alert("about name:"+name);
    alert("about add(1,1):"+add(1,1));
  }   
}   
  
  
//原型函数(由类的对象调用)   
testClass.prototype.walk = function(){   
  //只能访问:全局变量和全局函数   
  this.where = function(){   
    alert("Where can we go?");
    go();   
  }   
     
  var go = function(){   
    alert("go name:"+name);  
    alert("go add(1,1):"+add(1,1));
  }   
}   
</script> 



下面看看如何调用:

//获取一个cbs类的实例   
var cbs= new testClass();   
//调用类的对象属性age   
alert("age:"+cbs.age);   
  
//获取类函数talk的实例   
var talk = new testClass.talk();
//调用类函数的实例函数   
talk.what();   
  
//获取原型函数walk的实例   
var walk = new cbs.walk();   
//调用原型函数的实例函数   
walk.where();



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值