91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在javascript中使用this

發布時間:2021-01-11 15:43:58 來源:億速云 閱讀:169 作者:Leah 欄目:web開發

本篇文章給大家分享的是有關如何在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,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

漳浦县| 博白县| 桂东县| 衡阳市| 临沭县| 宣城市| 利津县| 安图县| 伊通| 竹溪县| 双鸭山市| 普兰县| 潜江市| 宁安市| 江达县| 四子王旗| 湟源县| 望江县| 田林县| 巴彦淖尔市| 贵溪市| 永靖县| 广灵县| 嵊州市| 太康县| 怀宁县| 花莲县| 宁陵县| 潍坊市| 旌德县| 和顺县| 区。| 长沙市| 大余县| 枣强县| 蓝田县| 武穴市| 定兴县| 大渡口区| 通化县| 宜州市|