首頁 > web前端 > js教程 > JS基礎隨筆(菜鳥必看篇)

JS基礎隨筆(菜鳥必看篇)

高洛峰
發布: 2017-01-21 09:36:34
原創
1373 人瀏覽過

在學習的過程中總會一次次的冒出以前囫圇吞棗的地方,以下將今天學到的一下知識點記錄下來方便以後查看。

JavaScript中的資料型別

簡單(基本)資料型態:Number、String、Boolean、Undefined、Null

複雜(引用)資料型態:Object、Array、Date、function等

下面)資料型別與複雜(引用)資料型態的差異:

簡單資料型別:在堆疊內直接儲存值,如下圖所示    

JS基礎隨筆(菜鳥必看篇)

複雜資料型別:在堆疊內儲存引用,如圖

JS基礎隨筆(菜鳥必看篇)

複雜資料類型:在堆疊內儲存引用,如下圖

在了解以上兩種資料類型的儲存方式之後可以區分兩者的不同,可透過做以下的練習:

var a =10;
  var b = a;
  //问:当改变a的值后,b的值是否发生改变
  a=20;
  console.log(b);  // 10
登入後複製
var s1 = new Object();
var s2 = s1;
//问:改变s1的属性后,s2相同的属性是否改变
s1.name = "mh";
console.log(s2.name);    //mh
登入後複製
function f2(arr)
     {
       arr = [9,8,7,6,5];//产生新的对象
       arr[0]=-100;
     }
     var array = [1,2,4,7,5];
     f2(array);
     console.log(array[0]);//  1
登入後複製

JavaSript中的變數提升,function聲明以及變數先看以下以下的一道面試題目:

var num = 10;
    fun();
    function fun()
    {
      console.log(num);
      var num =20;
    }
登入後複製

在沒有學習之前我會直接回答為10,現在學習JavaScript中的預編譯概念知道了var關鍵字的提升概念以及function的聲明概念知道了以上程式碼與下面程式碼等量:

var num;//全局作用域  遇到var和function 提升
     function fun() {
       var num ;  //局部做用户 遇到var 提升
       console.log(num);
       num =20;
     }
    num = 10;
    fun();
登入後複製

以上程式碼等同於以下程式碼:

//问题:为什么会出现下面的错误?
      //Uncaught TypeError:fnName is not a function
 
      console.log(fnName(1,2));
      var fnName = function (a,b) {
        return a + b;
      }
登入後複製

以上程式碼等同於以下程式碼:

var fnName;
      console.log(fnName(1,2));
      fnName = function (a,b) {
        return a + b;
      }
登入後複製

可以看到因為function在等號再看號會回報「Uncaught TypeError:fnName is not a function」錯誤。

了解變數的作用域可以看以下程式碼:

f1();
        console.log(c);
        console.log(b);
        console.log(a);
        function f1() {
          var a = b = c = 20;
          console.log(c);
          console.log(b);
          console.log(a);
        }
登入後複製

對於var a=b=c=20; 這類連續賦值,在局部作用域內只會對a再聲明,而b、c的作用域為全域作用域。所以只有全域作用域內的a報錯為"Uncaught ReferenceError: a is not defined"。

以上這篇JS基礎隨筆(菜鳥必看篇)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持PHP中文網。

🎜更多JS基礎隨筆(菜鳥必看篇)相關文章請關注PHP中文網! 🎜
相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板