JS函数this的用法实例分析


Posted in Javascript onFebruary 05, 2015

本文实例讲述了JS函数this的用法。分享给大家供大家参考。具体如下:

在js中写函数时,很多用到this. this究竟是什么,this是个关键字,是个指针,指向执行环境作用域,也称之为上下文。
先说下函数吧,个人理解是函数是在语言中重复调用的代码块.
在JS里,把函数赋值给对象的属性时,称之为方法
如:

var m={};
m.title='title';
m.show=function(){
alert(this.title)
}
m.show()

就是把函数作为对象m的方法来调用
这样的话,this指向的就是m这个对象.

直接调函数名的叫函数:

var a=1212;
function show(){
alert(a)//1212
}
show()// 1212

在全局环境里,可以把全局变量理解为window的属性,全局函数为window的方法
看下面的例子:

var m ={};
m.id='mmm';
m.show=function(){
  alert(this.id);
}
var a={};
a.id='aaa';
a.show=m.show;
a.show(); //aaa

a.show=m.show;  先理解这句话,因为函数是个对象,
m.show=function(){
  alert(this.id)
}

这表达式相当于a.show 与m.show同时引用指向

function(){
  alert(this.id)
}

其实相当于

a.show=function(){
  alert(this.id)
}

所以调用a.show()时,this指向的是a对象,
再看以下一个栗子

var m ={};
m.id='mmm'
m.show=function(){
  alert(this.id)
}
var a={}
a.id='aaa'
a.show=function(){
  m.show()
};
a.show(); //mmm

所以调用a.show()时,相当于调用了m.show()的方法,所以this.指向的是m对象。

再看以下一个例子,一开始还是不很懂

var color='red';
var app = {};
app.color="green";
app.paint=function(node){
node.style.color=this.color;
  alert(this.color);
}
function findNode(callback){
  var btn =document.querySelector('.btn');
  callback(btn);//传进来,
}
findNode(app.paint);
alert(this.color); //red 而不是green

函数传参时,是按值传参的,而不是引用

所以findNode(app.paint);传进来时,其实是

function(node){
  node.style.color=this.color;
  alert(this.color);
}

的引用,又因为findNode是全局定义的,所以this指向WINDOW OR UNDEFINED;

关于传参,按值传递过去的

function show(a){
  alert(a)
}

参数为基本数据类型时好理解

var b=10;
show(b)//alert(10);

至于对象

var c ={};
c.prop=true;
var showProp=function(obj){
obj.prop=false
}
showProp(c); //c.prop = false

有些人觉得是上面例子是按引用传参
其实上面还是按值传参,showProp(c)把c传进函数里时,c其实相当于一个引用, 函数里对obj.prop=false,相当于对引用的对象 改成{prop:false}

再看下面一例子

var c ={};
c.prop=true;
var showProp=function(obj){
  obj = new Object();
  obj.prop=false
  return obj;
}
showProp(c);
alert(c.prop); //true

这里明明把传入obj修改了,如果按照函数按引用传参,函数里面的修改肯定会反映到外部

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
28个JS验证函数收集
Mar 02 Javascript
javascript学习笔记(十二) RegExp类型介绍
Jun 20 Javascript
addEventListener 的用法示例介绍
May 07 Javascript
JavaScript中Window对象的属性及事件
Dec 25 Javascript
浅析如何利用angular结合translate为项目实现国际化
Dec 08 Javascript
JavaScript cookie详解及简单实例应用
Dec 31 Javascript
JS 实现随机验证码功能
Feb 15 Javascript
jquery点赞功能实现代码 点个赞吧!
May 29 jQuery
JS 中LocalStorage和SessionStorage的使用
Aug 17 Javascript
微信小程序实现简单跑马灯效果
May 26 Javascript
微信小程序自定义可滑动日历界面
Dec 28 Javascript
基于Angular 8和Bootstrap 4实现动态主题切换的示例代码
Feb 11 Javascript
IE下使用jQuery重置iframe地址时内存泄露问题解决办法
Feb 05 #Javascript
js关于命名空间的函数实例
Feb 05 #Javascript
js实现数字每三位加逗号的方法
Feb 05 #Javascript
javascript实现字符串反转的方法
Feb 05 #Javascript
Javascript中拼接大量字符串的方法
Feb 05 #Javascript
jquery操作select方法汇总
Feb 05 #Javascript
高性能JavaScript模板引擎实现原理详解
Feb 05 #Javascript
You might like
在线竞拍系统的PHP实现框架(一)
2006/10/09 PHP
php上传、管理照片示例
2006/10/09 PHP
解析php中memcache的应用
2013/06/18 PHP
php object转数组示例
2014/01/15 PHP
WordPress中给媒体文件添加分类和标签的PHP功能实现
2015/12/31 PHP
IE 条件注释详解总结(附实例代码)
2009/08/29 Javascript
关于js中window.location.href,location.href,parent.location.href,top.location.href的用法与区别
2010/10/18 Javascript
Jquery写一个鼠标拖动效果实现原理与代码
2012/12/24 Javascript
浅析jQuery中常用的元素查找方法总结
2013/07/04 Javascript
javascript实现左右控制无缝滚动
2014/12/31 Javascript
angular基于路由控制ui-router实现系统权限控制
2016/09/27 Javascript
微信小程序  生命周期详解
2016/10/27 Javascript
微信小程序模板之分页滑动栏
2017/02/10 Javascript
Node实战之不同环境下配置文件使用教程
2018/01/02 Javascript
Vue 监听列表item渲染事件方法
2018/09/06 Javascript
详解在网页上通过JS实现文本的语音朗读
2019/03/28 Javascript
JS highcharts实现动态曲线代码示例
2020/10/16 Javascript
js实现验证码干扰(静态)
2021/02/22 Javascript
[40:05]LGD vs Winstrike 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/18 DOTA
[46:28]EG vs Liquid 2019国际邀请赛淘汰赛 败者组 BO3 第二场 8.23
2019/09/05 DOTA
python数组复制拷贝的实现方法
2015/06/09 Python
使用python验证代理ip是否可用的实现方法
2018/07/25 Python
Djang的model创建的字段和参数详解
2019/07/27 Python
Python求平面内点到直线距离的实现
2020/01/19 Python
pytorch 移动端部署之helloworld的使用
2020/10/30 Python
Python 里最强的地图绘制神器
2021/03/01 Python
通过CSS3的object-fit来调整图片适配尺寸的技巧简介
2016/02/27 HTML / CSS
Staples加拿大官方网站:办公用品一站式采购
2016/09/25 全球购物
维珍澳洲航空官网:Virgin Australia
2017/09/08 全球购物
亚马逊巴西站:Amazon.com.br
2019/09/22 全球购物
PHP如何设置和取得Cookie值
2015/06/30 面试题
介绍一下HTTP、HTTPS和SSL
2012/12/16 面试题
语文教育专业应届生求职信
2013/11/23 职场文书
投标售后服务承诺书
2015/04/29 职场文书
Python使用pyecharts控件绘制图表
2022/06/05 Python
微信小程序纯CSS实现无限弹幕滚动效果
2022/09/23 HTML / CSS