2019独角兽企业重金招聘Python工程师标准>>>

本文为 H5EDU 机构官方 HTML5培训 教程,主要介绍:JavaScript强化教程——对象的值传递和引用传递

function SetName(obj){
obj.name="Tom";//执行之前,此时的obj和Person的name属性均为undefined
obj1=new Object();
obj1=obj;//声明一个全局对象,那么obj、obj1和Person此时应该是同一个对象
}//SetName函数执行完之后,obj对象销毁,其余对象仍然存在
Person=new Object();//声明Person对象
SetName(Person);//调用SetName函数并将对象作为参数传入
obj1.name="Lucy";//通过obj1改变Person的name属性
alert(Person.name);//输出“Lucy”,左边的代码结论给的感觉是,JavaScript的对象就是按引用传递
/*
我想知道在调用SetName(Person)的时候,Person传递到function SetName(obj)位置到底是值传递
还是引用传递,如果按照如下的说法-->摘抄至JavaScript高级教程(第三版)
function SetName(obj){
obj.name="Tom";
obj=new Object();
obj.name="Lucy";
}
Person=new Object();//声明Person对象
SetName(Person);//
alert(Person.name);//输出Tom
我感觉调用函数的时候Person和obj应该是用一个引用,但是是将function中的obj局部对象重新声明,我觉得在执行了obj=new Object()重新声明对象这个语句之后,
此时的obj和调用SetName(Person)的Person对象是不同的引用(地址), obj.name="Lucy";这句话对Person此时根本就没有起作用,所以才会有书中的结论,输出为“Tom"的结果,所以,我觉得书中的这个代码还是不足以证明JavaScript中对象是按值传递的这个结论,
我想请问如何去理解这个问题,谢谢大家*/再附上网上找的一段代码,在调用函数输入的都是对象,为什么有不同的结果:
<script type="text/javascript">
function foo(v3){
v3={a:3};
alert(v3.a);//3
}
var v4={};
foo(v4);
alert(v4.a);//undefined
</script>
<script type="text/javascript">
function fooled(v2){
v2.b=4;
alert(v2.b);//4
}
var v1=new Object();
fooled(v1);
alert(v1.b);//4
</script>

点击进入JS强化教程:http://www.h5edu.cn/htm/step/h5edu_44.html

转载于:https://my.oschina.net/zhanyingwang/blog/719887

JavaScript强化教程——对象的值传递和引用传递相关推荐

  1. JavaScript强化教程—— RegExp 对象

    为什么80%的码农都做不了架构师?>>>    本文为 H5EDU 机构官方 HTML5培训 教程,主要介绍:JavaScript强化教程 --RegExp 对象   RegExp ...

  2. JavaScript强化教程——JavaScript Math(算数) 对象

    为什么80%的码农都做不了架构师?>>>    本文为 H5EDU 机构官方 HTML5培训 教程,主要介绍:JavaScript强化教程 -- JavaScript Math(算数 ...

  3. JavaScript强化教程——数组的基本处理函数

    2019独角兽企业重金招聘Python工程师标准>>> 本文为 H5EDU 机构官方 HTML5培训 教程,主要介绍:JavaScript强化教程 -- 数组的基本处理函数 Arra ...

  4. JavaScript强化教程——从简到繁

    2019独角兽企业重金招聘Python工程师标准>>> 本文为H5EDU机构官方HTML5培训教程HTML5培训,主要介绍:JavaScript强化教程--javascript从简到 ...

  5. JavaScript强化教程——JavaScript 运算符

    本文为 H5EDU 机构官方 HTML5培训 教程,主要介绍:JavaScript强化教程 -- JavaScript 运算符  JavaScript 算术运算符 算术运算符用于执行两个变量或值的运算 ...

  6. JavaScript强化教程——javascript性能优化

    本文为 H5EDU 机构官方 HTML5培训 教程,主要介绍:JavaScript强化教程 --数据存取 数据的存取位置也影响着JavaScript的运行速度,我们来总结一下如能分配存取位置最合理,能 ...

  7. javascript之值传递与引用传递

    javascript之值传递与引用传递 在分析这个问题之前,我们需了解什么是按值传递(call by value),什么是按引用传递(call by reference).在计算机科学里,这个部分叫求 ...

  8. JavaScript强化教程——jQuery选择器

    本文为 H5EDU 机构官方 HTML5培训 教程,主要介绍:JavaScript强化教程 -- jQuery选择器 jQuery 选择器 选择器 实例 选取 * $("*") 所 ...

  9. JavaScript强化教程 —— JavaScript 总结

    本文为 H5EDU 机构官方 HTML5培训 教程,主要介绍:JavaScript强化教程 -- JavaScript 总结 本教程中我们向您讲授了如何向 html 页面添加 JavaScript,使 ...

最新文章

  1. oracle 10035 err 942,案例:Oracle日志报错 Fatal NI connect error 12170 TNS-12535 TNS-00505
  2. 命名空间和模块化编程3
  3. sas table将缺失值计入百分比_SAS:通过数据块填充缺失值
  4. 《大道至简》第一章伪代码
  5. 开发针对特殊租户的Teams机器人
  6. 正则判断字符串是否为数字
  7. ant压缩和解压缩工具类
  8. windows 获取系统CPU和进程CPU 内存等信息
  9. java中面向对象租车问题_答答租车系统-Java面向对象的学习
  10. python中set index_Python set_index和reset_index详解
  11. java 内部类调用_Java内部类使用总结
  12. tensorflow图片读取
  13. 谷歌大脑科学家 Caffe缔造者 贾扬清 微信讲座
  14. 生物信息学数据库及在线工具汇总 (更新)
  15. 服务器修改动态磁盘,如何创建动态磁盘
  16. C语言变量命名有哪些规则,C语言变量的命名规则都有哪些?
  17. win7计算机用户配置文件存储路径,windows7系统电脑临时文件夹保存路径在哪
  18. Bzoj3653 谈笑风生
  19. 算法【动态规划】 | 【01】二维表结构
  20. 老罗的《Android系统源代码情景分析》翻了10遍还看不懂?因为你用错了

热门文章

  1. Python学习入门基础教程(learning Python)--6.3 Python的list切片高级
  2. linux下java还原mysql数据库
  3. 嵌入式系统在井下煤炭井下监控系统的应用
  4. 关于JS客户端对服务器控件赋值,Post后不能保留值的解决办法
  5. [洛谷P4721]【模板】分治 FFT
  6. 如何将本地的项目加入git管理?
  7. postman指定User-Agent的header无效
  8. POJ_2536_Gopher II
  9. Swift入门篇-基本类型(1)
  10. 50多种适合机器学习和预测应用的API,你的选择是?(2018年版本)