位置: 编程技术 - 正文

JavaScript修改作用域外变量的方法(js修改内容)

编辑:rootadmin

推荐整理分享JavaScript修改作用域外变量的方法(js修改内容),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js修改hover,编辑修改js文件,js怎么修改,js修改ua,javascript修改文本,js修改ua,编辑修改js文件,javascript修改文本,内容如对您有帮助,希望把文章链接给更多的朋友!

1.今天在看JavaScript学习指南的时候做的课后习题,也因此详细的对函数的传入参数进行比较深入的研究.

题目如下:

  函数如何才能修改其作用域之外的变量&#;编写一个函数,由1~5的数字组成的数组作为参数,调用该函数后将把其中的数字项替换为相应的字符串表示形式.

需要注意知识点:

  在JavaScript中函数参数的传递,对于基于原始值的参数进行值传递(数字,字符串,布尔值),函数中的修改不会影响实际参数值.而传递给函数的参数而言,对象是一个引用,对其的修改的将会反映在主调程序中.<-但是,会有这样的情况,如下

在上面代码中我们创建了4个全局变量,类型分别为数字,布尔值,数组,对象.2个函数,display和test.

display执行了4次,分别结果如下:

"number:2boolean:truearray:1,2,3object:"<-传入函数时的值

"number:0boolean:falsearray:1,2,3,3object:"<-执行更改

"number:0boolean:falsearray:3,2,1object:"<-重新赋值

"number:2boolean:truearray:1,2,3,3object:"<-函数执行完毕后

可以看出我们对数组和对象的重新赋值并没有成功,如果按引用传递,那么我们应该也对全局变量的数组和对象重新赋值修改了呀.其实JavaScript中所谓的按引用赋值并不是真正意义上的按引用复制,准确说应该是按共享传递.也可以叫按对象传递,按对象共享传递(call by sharing).

在这个按共享传递的条件下,我们获取的引用可以说只是实参引用的副本,它和我们经常说的按引用传递的最大差别就在于我们在对引用副本的赋值不会影响实参的值,正如我们上面那样做的那样,赋值操作是不可行的.

当然我们从对象类型和基本类型两方面看,对象是可变的而基本类型是不可变的(注意!字符串修改其实是返回的新的字符串),所以按共享传递对于基本类型来说也是符合按共享传递的.

总结一下:

JavaScript修改作用域外变量的方法(js修改内容)

  JavaScript中,基本类型和对象都按共享传递(call by sharing),但是由于JavaScript的基本类型的不变性,基本类型按共享传递与按值传递没有任何区别,而对象按共享传递.

按共享传递(call by sharing):传递的是实参引用的副本,我们对引用副本的赋值不影响实参的值,但是可以使用引用副本去修改引用的内容.详细的wiki地址

函数对传入的参数:

1.基本类型,按值传递(或者也可以说按共享传递),内部赋值修改都不影响主调程序

2.对象类型,按共享传递,传入的为实参引用的副本,内部对该引用的赋值无效,对对象属性的赋值修改有效.

大概就是这么理解了,假如有什么地方我犯了什么错误,也希望能被指出来.

下面单独拉出JavaScript作用域

  任何程序设计语言都有作用域的概念,简单的说,作用域就是变量与函数的可访问范围,即作用域控制着变量与函数的可见性和生命周期。在JavaScript中,变量的作用域有全局作用域和局部作用域两种。

   全局作用域(Global Scope)

  在代码中任何地方都能访问到的对象拥有全局作用域,一般来说以下几种情形拥有全局作用域:

  (1)最外层函数和在最外层函数外面定义的变量拥有全局作用域,例如:

  (2)所有末定义直接赋值的变量自动声明为拥有全局作用域,例如:

  变量blogName拥有全局作用域,而authorName在函数外部无法访问到。

  (3)所有window对象的属性拥有全局作用域

  一般情况下,window对象的内置属性都拥有全局作用域,例如window.name、window.location、window.top等等。

  1. 局部作用域(Local Scope)  

  和全局作用域相反,局部作用域一般只在固定的代码片段内可访问到,最常见的例如函数内部,所有在一些地方也会看到有人把这种作用域称为函数作用域,例如下列代码中的blogName和函数innerSay都只拥有局部作用域。

JavaScript实现弹出DIV层同时页面背景渐变成半透明效果 本文实例讲述了JavaScript实现弹出DIV层同时页面背景渐变成半透明效果。分享给大家供大家参考,具体如下:!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""ht

详解Javascript继承的实现 本文从以下四个方面展开话题:1.混合方式实现及问题2.期望的调用方式3.继承库的详细实现4.总结感兴趣的朋友可以继续往下阅读详情。我最早掌握的在

JS+CSS实现的漂亮渐变背景特效代码(6个渐变效果) 本文实例讲述了JS+CSS实现的漂亮渐变背景特效代码。分享给大家供大家参考,具体如下:运行效果截图如下:具体代码如下:htmlheadtitleJS配合CSS实现的

标签: js修改内容

本文链接地址:https://www.jiuchutong.com/biancheng/375953.html 转载请保留说明!

上一篇:JavaScript 2048 游戏实例代码(简单易懂)

下一篇:JavaScript实现弹出DIV层同时页面背景渐变成半透明效果(js实现弹窗)

  • 如何分辨海关完税凭证的真假?
  • 财税通财务软件如何调整凭证间距
  • 一般纳税人缴纳增值税会计科目
  • 甲方应项目具备开工条件
  • 技术使用费所得税怎么算
  • 预缴的附加税月末结转吗
  • 用自产货物用抵债交换是否视同销售
  • 事业单位固定资产
  • 支付宝怎么开个人增值税发票
  • 固定资产原值的含义
  • 企业促销应该采用什么方法
  • 美元转到中国账户可不可以取人民币
  • 单位购入新车的发票
  • 公司罚款作为一种对过错方式的处罚
  • 固定资产减值准备增加记哪方
  • 学校里的水电费是政府买单吗
  • 营改增后增值税暂行条例实施细则
  • 学生兼职需要交什么税
  • 预提 冲销
  • 结转开发产品
  • 办公软件无形资产的确认条件有哪些
  • 公司哪些发票可以做成本或者费用
  • 自行生产的存货转固定资产怎么做账
  • 企业残疾人保障金的缴纳标准
  • 已计提月份的公式
  • linux dns配置服务器
  • 华为手机哪一款好用性价比高
  • web投票系统源码
  • 公司有长期挂账的权利吗
  • wgcore.dll是什么文件夹
  • phpsessid是什么
  • 火灾烧毁物品如何取证
  • 建筑行业现在还能斤不
  • c++ array
  • php框架基础教程
  • 收到境外服务费可以退税吗
  • 报废机器设备如何缴纳增值税
  • 出售自建不动产怎么交税
  • 农业企业所得税是免税的吗
  • 进出口额等于进口额加出口额吗
  • 非贸备案什么意思
  • 购买的无形资产交印花税吗?
  • 附加税申报核心内容
  • 现金日记账应采用的格式为订本式
  • 企业所得税该什么科目
  • 一年的房租费摊销的账务处理
  • 代开专票上的税额比电子缴款凭证上的税额少怎么调整?
  • 消费税计税分录
  • 原始凭证的基本内容有会计分录吗
  • 收购发票如何确认成本
  • 凭证必须用凭证盒
  • 应收帐款的帐务处理流程
  • 预提房租会计分录怎么填
  • 以前年度的损益调整为负值说明什么
  • 员工餐补是放入福利费吗?
  • 小规模纳税人发票可以抵扣吗
  • 工程类发票账务后面需附什么单据呢
  • 应付职工薪酬属不属于流动负债
  • mysql连接时间长怎么优化
  • mysql的json数据类型
  • mysql数据库开发技术
  • centos查找目录命令
  • xp系统内存不能为read的解决方法
  • macbookpro中的文本编辑
  • 盗版win10可以用win10商店吗
  • linux分区方案lvm
  • scanserver.exe - scanserver是什么进程 有什么用
  • 电脑跳出windows 许可
  • win7电脑无限蓝屏怎么解决
  • Javascript中的this
  • jquery打开本地html
  • javascript的代码写在哪里
  • unity控制组件开关
  • JavaScript+html5 canvas绘制渐变区域完整实例
  • 深入理解新发展理念,推进供给侧结构性改革
  • javascript教学视频
  • python的web框架
  • 挂车买保险是怎么买的
  • 太原市地税局各分局局长
  • 北京ca证书下载安装流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设