关于 byval 与 byref 的区别分析总结


Posted in Javascript onOctober 08, 2007

二者区别:
byval 传递数值,实参和形参分处不同的内存单元,互不干扰! 
byref 传递地址,实参和形参占用相同的内存单元,形参变则实参变!!!!!!
通俗理解:
byval 一去不复返 
byref 进去再出来,可能被更新!
在JavaScript中:
Boolean,Number,String型的参数是按值传递的 ==> 相当于VBS中的ByVal;
而Object型的参数(包括JS对象,Array对象,Function对象等),是按引用传递 ==> 相当于VBS中的ByRef

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
<html xmlns="http://www.w3.org/1999/xhtml" lang="zh-CN">  
<head>  
<title> 函数传值测试 </title>  
<meta http-equiv="content-type" content="text/html; charset=utf-8" />  
<meta name="author" content="枫岩,CNLEI" />  
<meta name="copyright" content="cnlei.y.l@gmail.com , http://www.cnlei.com" />  
</head>  
<body>  
<script type="text/javascript">  
<!--  
function Num(n){n=n*2;}//Number型的参数,按值传递的 ==> 相当于VBS中的ByVal;  
function Obj(){}  
Obj.prototype.show = function(o){ //JS对象,是按引用传递 ==> 相当于VBS中的ByRef  
  o.toString = function(){  
    return("{id:"+this.id+",desc:"+this.desc+"}");  
  }  
}  
function Func(f){ //Function对象,是按引用传递 ==> 相当于VBS中的ByRef  
  f.show = function(o){  
    o.toString = function(){  
      return("{id:"+this.id+",desc:"+this.desc+",toString:function(){} }");  
    }  
  }  
}  var N;  
N=1;  
alert(N);  
Num(N);  
alert(N);  
var O;  
O = {  
  id:"001",  
  desc:"编号说明",  
  toString: function (){  
    return null;  
  }  
};  
var F = new Obj();  
var F2 = new Obj();  
alert(O.id+"\n"+O.toString());  
F.show(O);  
alert(O.id+"\n"+O.toString());  
Func(F);  
F.show(O);  
alert(O.id+"\n"+O.toString());  
//-->  
</script>  
</body>  
</html> 
Javascript 相关文章推荐
你所要知道JS(DHTML)中的一些技巧
Jan 09 Javascript
jQuery中parents()方法用法实例
Jan 07 Javascript
深入理解JavaScript系列(48):对象创建模式(下篇)
Mar 04 Javascript
JS Array创建及concat()split()slice()的使用方法
Jun 03 Javascript
AngularJS教程 ng-style 指令简单示例
Aug 03 Javascript
微信公众号支付H5调用支付解析
Nov 04 Javascript
JavaScript实现倒计时跳转页面功能【实用】
Dec 13 Javascript
vue2.0 常用的 UI 库实例讲解
Dec 12 Javascript
详解Nuxt.js中使用Element-UI填坑
Sep 06 Javascript
mpvue实现小程序签到金币掉落动画(api实现)
Oct 17 Javascript
vue实现匀速轮播效果
Jun 29 Javascript
Vue ElementUI实现:限制输入框只能输入正整数的问题
Jul 31 Javascript
JavaScript加密解密7种方法总结分析
Oct 07 #Javascript
JavaScript 入门·JavaScript 具有全范围的运算符
Oct 01 #Javascript
javascript入门·动态的时钟,显示完整的一些方法,新年倒计时
Oct 01 #Javascript
javascript入门·图片对象(无刷新变换图片)\滚动图像
Oct 01 #Javascript
javascript入门·对象属性方法大总结
Oct 01 #Javascript
JS创建优美的页面滑动块效果 - Glider.js
Sep 27 #Javascript
[HTML/CSS/Javascript]WWTJS
Sep 25 #Javascript
You might like
PHP数据库操作Helper类完整实例
2016/05/11 PHP
一键生成各种尺寸Icon的php脚本(实例)
2017/02/08 PHP
jQuery渐变发光导航菜单的实例代码
2013/03/27 Javascript
js判断屏幕分辨率的代码
2013/07/16 Javascript
实现动画效果核心方式的js代码
2013/09/27 Javascript
jquery实现手机发送验证码的倒计时代码
2014/02/12 Javascript
9款2014最热门jQuery实用特效推荐
2014/12/07 Javascript
jQuery插件jcrop+Fileapi完美实现图片上传+裁剪+预览的代码分享
2015/04/22 Javascript
JavaScript 封装一个tab效果源码分享
2015/09/15 Javascript
关于JavaScript限制字数的输入框的那些事
2016/08/14 Javascript
jQuery插件easyUI实现通过JS显示Dialog的方法
2016/09/16 Javascript
Bootstrap Table表格一直加载(load)不了数据的快速解决方法
2016/09/17 Javascript
Bootstrap BootstrapDialog使用详解
2017/02/17 Javascript
微信小程序实现MUI数字输入框效果
2018/01/31 Javascript
前端开发之便利店收银系统代码
2019/12/27 Javascript
Python实现程序的单一实例用法分析
2015/06/03 Python
浅谈Python 集合(set)类型的操作——并交差
2016/06/30 Python
Python抓取框架 Scrapy的架构
2016/08/12 Python
解决python3 网络请求路径包含中文的问题
2018/05/10 Python
python os用法总结
2018/06/08 Python
python实现ftp文件传输功能
2020/03/20 Python
Python datetime模块使用方法小结
2020/06/18 Python
html5中valid、invalid、required的定义
2014/02/21 HTML / CSS
Missguided美国官网:英国时尚品牌
2018/01/18 全球购物
俄语地区最大的中国商品在线购物网站之一:Umka Mall
2019/11/03 全球购物
高中毕业自我鉴定
2013/12/22 职场文书
财务部总监岗位职责
2014/03/12 职场文书
元旦趣味活动方案
2014/08/22 职场文书
干部四风问题整改措施思想汇报
2014/10/13 职场文书
党校党性分析材料
2014/12/19 职场文书
2015年教师节感恩寄语
2015/03/23 职场文书
2015年人事科工作总结
2015/04/28 职场文书
2015年司机年终工作总结
2015/05/14 职场文书
如何搭建 MySQL 高可用高性能集群
2021/06/21 MySQL
Python一些基本的图像操作和处理总结
2021/06/23 Python
关于python pygame游戏进行声音添加的技巧
2021/10/24 Python