Angular.JS中的this指向详解

发布时间 - 2026-01-11 01:09:02    点击率:

【this详解】

1、谁最终调用函数,this指向谁。

      ① this指向的,永远只可能是对象!!!!!!

      ② this指向谁,永远不取决于this写在哪!!而是取决于函数在哪调用。

      ③ this指向的对象,我们称之为函数的上下文context,也叫函数的调用者

2、※※※※※this指向的规律(与函数调用的方式息息相关):

this指向的情况,取决于函数调用的方式有哪些:

      ① 通过函数名()直接调用:this指向window

      ② 通过对象.函数名()调用的:this指向这个对象

      ③ 函数作为数组的一个元素,通过数组下标调用的:this指向这个数组

      ④ 函数作为window内置函数的回调函数调用:this指向window setInterval  setTimeout 等...

      ⑤ 函数作为构造函数,用new关键字调用时:this指向新new出的对象 

function func(){
   console.log(this);
  }

① 通过函数名()直接调用:this指向window

func(); this--->window

② 通过对象.函数名()调用的:this指向这个对象

     狭义对象

 var obj = {
 name:"obj",
 func1 :func
 };
 obj.func1(); this--->obj

     广义对象

 document.getElementById("div").onclick = function(){
 this.style.backgroundColor = "red";
 }; this--->div

③ 函数作为数组的一个元素,通过数组下标调用的:this指向这个数组

var arr = [func,1,2,3];
arr[0](); this--->arr

④ 函数作为window内置函数的回调函数调用:this指向window

setTimeout(func,1000);// this--->window
setInterval(func,1000);

⑤ 函数作为构造函数,用new关键字调用时:this指向新new出的对象

var obj = new func(); //this--->new出的新obj

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


# angular  # this  # 指向  # angularjs  # angularjs中的this  # JS中改变this指向的方法(call和apply、bind)  # 详解JS中定时器setInterval和setTImeout的this指向问题  # js绑定事件this指向发生改变的问题解决方法  # JS匿名函数内部this指向问题详析  # 关于JavaScript中的this指向问题总结篇  # JS 箭头函数的this指向详解  # 详解JavaScript中关于this指向的4种情况  # javascript改变this指向的方法汇总  # 回调  # 直接调用  # 息息相关  # 这篇文章  # 谢谢大家  # 写在  # 也叫  # 称之为  # 有哪些  # 调用者  # 有疑问  # window  # span  # setInterval  # setTimeout  # style  # strong  # nbsp  # br  # color 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】  Laravel如何理解并使用服务容器(Service Container)_Laravel依赖注入与容器绑定说明  通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】  如何快速搭建二级域名独立网站?  如何快速生成ASP一键建站模板并优化安全性?  Laravel怎么为数据库表字段添加索引以优化查询  如何用虚拟主机快速搭建网站?详细步骤解析  黑客如何通过漏洞一步步攻陷网站服务器?  如何在阿里云虚拟主机上快速搭建个人网站?  黑客如何利用漏洞与弱口令入侵网站服务器?  如何在Windows环境下新建FTP站点并设置权限?  Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程  企业网站制作这些问题要关注  如何在宝塔面板中修改默认建站目录?  Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势  Laravel Eloquent:优雅地将关联模型字段扁平化到主模型中  Google浏览器为什么这么卡 Google浏览器提速优化设置步骤【方法】  南京网站制作费用,南京远驱官方网站?  Laravel如何生成和使用数据填充?(Seeder和Factory示例)  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  JS实现鼠标移上去显示图片或微信二维码  Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】  Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析  php结合redis实现高并发下的抢购、秒杀功能的实例  如何在阿里云域名上完成建站全流程?  今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  如何用IIS7快速搭建并优化网站站点?  如何快速选择适合个人网站的云服务器配置?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】  C#如何调用原生C++ COM对象详解  大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?  Laravel怎么解决跨域问题_Laravel配置CORS跨域访问  怎么用AI帮你为初创公司进行市场定位分析?  Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】  php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】  如何快速生成橙子建站落地页链接?  如何用腾讯建站主机快速创建免费网站?  Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】  如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)  Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)  实例解析angularjs的filter过滤器  如何快速上传自定义模板至建站之星?  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  如何在建站宝盒中设置产品搜索功能?  UC浏览器如何设置启动页 UC浏览器启动页设置方法  网站建设整体流程解析,建站其实很容易!