关于 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 弹出框口并返回值的两种常用方法
Dec 30 Javascript
深入分析JSONP跨域的原理
Dec 10 Javascript
详细分析JavaScript变量类型
Jul 08 Javascript
JSON与XML优缺点对比分析
Jul 17 Javascript
详解JavaScript中的事件流和事件处理程序
May 20 Javascript
jquery组件WebUploader文件上传用法详解
Oct 23 Javascript
微信小程序实现action-sheet弹出底部菜单功能【附源码下载】
Dec 09 Javascript
jQuery实现参数自定义的文字跑马灯效果
Aug 15 jQuery
vue 点击展开显示更多(点击收起部分隐藏)
Apr 09 Javascript
详解mpvue实现对苹果X安全区域的适配
Jul 31 Javascript
基于Web Audio API实现音频可视化效果
Jun 12 Javascript
JavaScript文档加载模式以及元素获取
Jul 28 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生成文件
2007/01/15 PHP
PHP中__get()和__set()的用法实例详解
2013/06/04 PHP
php多个文件及图片上传实例详解
2014/11/10 PHP
PHP版本如何选择?应该使用哪个版本?
2015/05/13 PHP
PHP面向对象详解(三)
2015/12/07 PHP
yii2.0实现创建简单widgets示例
2016/07/18 PHP
PHP实现对xml进行简单的增删改查(CRUD)操作示例
2017/05/19 PHP
PHP实现超简单的SSL加密解密、验证及签名的方法示例
2017/08/28 PHP
PHP PDO数据库操作预处理与注意事项
2019/03/16 PHP
laravel 解决后端无法获取到前端Post过来的值问题
2019/10/22 PHP
Javascript实例教程(19) 使用HoTMetal(5)
2006/12/23 Javascript
21个值得收藏的Javascript技巧
2014/02/04 Javascript
使用JavaScript实现网页版Pongo设计思路及源代码分享
2014/06/16 Javascript
jQuery+jsp下拉框联动获取本地数据的方法(附源码)
2015/12/03 Javascript
NodeJS使用七牛云存储上传文件的方法
2017/07/24 NodeJs
angular异步验证防抖踩坑实录
2019/12/01 Javascript
[02:06]DOTA2肉山黑名单魔法终结者 敌法师中文配音鉴赏
2013/06/17 DOTA
[02:32]DOTA2英雄基础教程 美杜莎
2014/01/07 DOTA
[00:33]2016完美“圣”典风云人物:BurNIng宣传片
2016/12/10 DOTA
Python创建对称矩阵的方法示例【基于numpy模块】
2017/10/12 Python
Python3.6中Twisted模块安装的问题与解决
2019/04/15 Python
Django Rest framework权限的详细用法
2019/07/25 Python
Python IDE Pycharm中的快捷键列表用法
2019/08/08 Python
Python如何急速下载第三方库详解
2020/11/02 Python
Python读取ini配置文件传参的简单示例
2021/01/05 Python
css3圆角样式分享自定义按钮样式
2013/12/27 HTML / CSS
德国香水、化妆品和护理产品网上商店:Parfumdreams
2018/09/26 全球购物
您附近的水疗和健康场所:Spafinder(美国)
2019/07/05 全球购物
Timberland德国官网:靴子、鞋子、衣服、夹克及配件
2019/12/10 全球购物
《要下雨了》教学反思
2014/02/17 职场文书
企业仓管员岗位职责
2014/06/15 职场文书
接待员岗位职责
2015/02/13 职场文书
大学生入党自荐书
2015/03/05 职场文书
长征观后感
2015/06/09 职场文书
解约证明模板
2015/06/19 职场文书
React列表栏及购物车组件使用详解
2021/06/28 Javascript