亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

JavaScript

JavaScript實例講解

時間:2024-08-29 07:25:08 JavaScript 我要投稿
  • 相關推薦

JavaScript實例講解

  這帶來的好處是內(nèi)部函數(shù)可以訪問定義它們的外部函數(shù)的參數(shù)和變量。

  首先,我們來構造一個簡單的對象。

  復制代碼 代碼如下:

  var testObj = {

  value: 10,

  add: function(inc){

  this.value += (typeof inc === "number") ? inc : 1;

  }

  };

  testObj.add();

  testObj.value; // 11

  testObj.add(2);

  testObj.value; // 13

  這樣寫就有一個問題,value值不能保證不會被非法修改,可以按如下的方法進行修改。

  復制代碼 代碼如下:

  var testObj = (function(){

  var value = 10;

  return {

  add: function(inc){

  value += (typeof inc === "number") ? inc : 1;

  },

  getValue: function(){

  return value;

  }

  };

  })();

  testObj.add();

  testObj.getValue(); // 11

  testObj.add(2);

  testObj.getValue(); // 13

  我們可以通用調(diào)用一個函數(shù)的形式去初始化testObj,該函數(shù)會返回一個對象字面量,函數(shù)里定義了一個value變量,該變量對add和getValue方法總是可用的,但函數(shù)的作用域使得它對其他的程序來說是不可見的。同時,我們還可以得出一個結論,內(nèi)部函數(shù)擁有比它的外部函數(shù)更長的生命周期。

  我們再繼續(xù)看一個構造函數(shù)調(diào)用的例子。

  復制代碼 代碼如下:

  var MyObj = function(str){

  this.status = str;

  };

  MyObj.prototype.getStatus = function(){

  return this.status;

  };

  var obj = new MyObj("javascript");

  obj.getStatus(); // "javascript"

  這樣寫并沒有錯,但是會有一點“多此一舉”,為什么要用一個getStatus方法去訪問一個本可以直接訪問到的屬性呢?如果status是私有屬性,那當然才有意義。

  復制代碼 代碼如下:

  var obj = function(status){

  return {

  getStatus: function(){

  return status;

  }

  };

  };

  var myObj = obj("javascript");

  myObj.getStatus(); // "javascript"

  這里當我們調(diào)用obj的時候,它返回包含getStatus方法的一個新對象,該對象的一個引用保存在myObj中,即使obj已經(jīng)返回了,但getStatus方法仍然享有訪問obj對象的status屬性的特權。getStatus方法并不是訪問該參數(shù)的一個副本,它訪問的就是該參數(shù)本身。這是可能的,因為該函數(shù)可以訪問它被創(chuàng)建時所處的上下文環(huán)境,這被稱為閉包。

【JavaScript實例講解】相關文章:

原生ajax調(diào)用數(shù)據(jù)實例簡單講解07-19

如何調(diào)試javascript腳本呢07-19

javascript跨域訪問的方法07-19

高爾夫技巧講解11-15

導游講解技巧04-09

泡茶的詳細步驟講解06-07

吉他入門技巧講解01-12

足球籬笆戰(zhàn)術講解02-20

象棋怎么下及口訣講解11-09

足球造越位戰(zhàn)術講解11-23