您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關如何在javascript中使用this,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
實踐一:this在點擊等事件中的指向
html結構:
<button id='btn'>click me</button>
javascript結構:
var btn = document.getElementById('btn'); btn.onclick = function(event) { console.log(this.innerHTML); // click me // 還有另一種做法如下,用事件對象 var evt = event || window.event; var target = evt.target || evt.srcElement; console.log(target.innerHTML); // click me }
實踐二:this在對象字面量json中的指向,指向自身對象
var p = { "name":"Tom", "say":function(){ console.log(this.name + ' say something!'); } } p.say(); // Tom say something!
實踐三:this在全局作用域中的使用
var a = 1; console.log(this); // window console.log(this.a); // 1 function test(){ console.log(this); // window this.haha = 'i am haha'; }; test(); // 函數一執行,haha 作用域變成全局的 console.log(haha); // i am haha
實踐四:this在定時器中的指向,定時器是window對象的一個方法,定時器中的this指向window對象,setTimeout()
和 setInterval()
是一樣的
var div = document.getElementById('div'); div.onclick = function() { var that = this; // 用that 來存儲當前的div這個dom元素 setTimeout(function(){ console.log(this + ' i am this'); // [object Window] i am this console.log(that + ' i am that'); // [object HTMLDivElement] i am that }, 100); }
實踐五:this在對象中的指向,指向當前實例對象
function Person(){ this.name = 'jack'; }; Person.prototype = { buy:function() { console.log(this.name + ' go buy!'); } } var p = new Person(); console.log(p.name); // jack; p.buy(); // jack go buy!
實踐六:this在閉包中的應用1
var age = 20; var person = { "age" : 10, "getAgeFunc" : function(){ return function(){ return this.age; // this 指向 window }; } }; console.log(person.getAgeFunc()()); // 20 /* 分析這段代碼:person調用getAgeFunc() 在內存中返回一個函數,這個函數是全局的,然后加個() 執行。那么,返回20 */
實踐七:this在閉包中的應用2
var age = 20; var person = { "age" : 10, "getAgeFunc" : function(){ var that = this; return function(){ return that.age; // that 指向 person }; } }; console.log(person.getAgeFunc()()); // 10 /* 分析這段代碼:person調用getAgeFunc() 用that代替當前對象,當執行返回的閉包函數時,age是person對象的一個屬性那么,返回10 */
實踐八:用call和apply改變this的指向 ,以后會詳細分析 call和apply以及閉包的概念
var person = { "name":"Tom", "say":function(x,y) { console.log(this.name + ' say ' + x + ' ' + y); } } var student = { "name":"Lucy" } person.say.call(student,'hello','world'); // Lucy say hello world person.say.apply(student,['hello','javascript']); // Lucy say hello javascript
以上就是如何在javascript中使用this,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。