欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript學(xué)習(xí)筆記(一)基礎(chǔ)知識

 更新時間:2014年09月30日 09:16:46   投稿:hebedich  
本文是學(xué)習(xí)筆記系列的第一篇,跟以前一樣,介紹些基礎(chǔ)知識,包括js基本概念、 JScript 的變量、js的數(shù)據(jù)類型、3.JScript 的運算符、js流程控制、js函數(shù)。有需要的朋友可以參考下

基本概念

javascript是一門解釋型的語言,瀏覽器充當(dāng)解釋器。
js執(zhí)行引擎并不是一行一行的執(zhí)行,而是一段一段的分析執(zhí)行。 

延遲腳本

HTML4.0.1中定義了defer屬性,它的用途是表明腳本在執(zhí)行時不會影響頁面的構(gòu)造。也就是說,腳本會延遲到整個頁面都解析完畢后再執(zhí)行。因此,在<script>元素中設(shè)置defer屬性,相當(dāng)于告訴瀏覽器立即下載,但延遲執(zhí)行。在XHTML文檔中,要把defer屬性設(shè)置為defer=“defer"

異步腳本

html5為<script>定義了async屬性。整個屬性與defer屬性類似,都用于改變處理腳本的行為。同樣,與defer類似,async只適用于外部腳本文件,并告訴瀏覽器立即下載文件。但與defer不同的是,標(biāo)記為async的腳本并不保證按照指定他們的先后順序執(zhí)行。
指定async的目的是不讓頁面等待腳本文件下載和執(zhí)行,從而異步加載頁面其他內(nèi)容。因此,建議異步腳本不要再加載期間操作DOM

區(qū)分大小寫

ECMASCript中的一切(包括變量,函數(shù)名和操作符)都區(qū)分大小寫。

1. JScript 的變量

變量在第一次用到時就設(shè)置于內(nèi)存中,便于后來在腳本中引用。使用變量之前先進行聲明??梢允褂?var 關(guān)鍵字來進行變量聲明。

var count, amount, level; // 用單個 var 關(guān)鍵字聲明的多個聲明。

變量命名

變量名包括全局變量,局部變量,類變量,函數(shù)參數(shù)等等,他們都屬于這一類。

變量命名都以類型前綴+有意義的單詞組成,用駝峰式命名法增加變量和函式的可讀性。例如:sUserName,nCount。

前綴規(guī)范:
每個局部變量都需要有一個類型前綴,按照類型可以分為:

s:表示字符串。例如:sName,sHtml;
n:表示數(shù)字。例如:nPage,nTotal;
b:表示邏輯。例如:bChecked,bHasLogin;
a:表示數(shù)組。例如:aList,aGroup;
r:表示正則表達式。例如:rDomain,rEmail;
f:表示函數(shù)。例如:fGetHtml,fInit;
o:表示以上未涉及到的其他對象,例如:oButton,oDate;
g:表示全局變量,例如:gUserName,gLoginTime;

JScript 是一種區(qū)分大小寫的語言。創(chuàng)建合法的變量名稱應(yīng)遵循如下規(guī)則:

注意第一個字符不能是數(shù)字。
后面可以跟任意字母或數(shù)字以及下劃線,但不能是空格
變量名稱一定不能是 保留字。

javascript是一種弱類型語言,JavaScript 會忽略多余的空格。您可以向腳本添加空格,來提高其可讀性。

varjavascript的保留字,表明接下來是變量說明,變量名是用戶自定義的標(biāo)識符,變量之間用逗號分開。

如果聲明了一個變量但沒有對其賦值,該變量存在,其值為Jscript 值 undefined。

強制類型轉(zhuǎn)換

在 Jscript 中,可以對不同類型的值執(zhí)行運算,不必擔(dān)心 JScript 解釋器產(chǎn)生異常。相反,JScript 解釋器自動將數(shù)據(jù)類型之一改變(強制轉(zhuǎn)換)為另一種數(shù)據(jù)類型,然后執(zhí)行運算。例如:

運算 結(jié)果

數(shù)值與字符串相加  將數(shù)值強制轉(zhuǎn)換為字符串。
布爾值與字符串相加  將布爾值強制轉(zhuǎn)換為字符串。
數(shù)值與布爾值相加  將布爾值強制轉(zhuǎn)換為數(shù)值。

要想顯式地將字符串轉(zhuǎn)換為整數(shù),使用 parseInt 方法。要想顯式地將字符串轉(zhuǎn)換為數(shù)字,使用 parseFloat 方法。

JavaScript 變量的生存期:當(dāng)您在函數(shù)內(nèi)聲明了一個變量后,就只能在該函數(shù)中訪問該變量。當(dāng)退出該函數(shù)后,這個變量會被撤銷。這種變量稱為本地變量。您可以在不同的函數(shù)中使用名稱相同的本地變量,這是因為只有聲明過變量的函數(shù)能夠識別其中的每個變量。
如果您在函數(shù)之外聲明了一個變量,則頁面上的所有函數(shù)都可以訪問該變量。這些變量的生存期從聲明它們之后開始,在頁面關(guān)閉時結(jié)束。

js變量思維導(dǎo)圖

2.js的數(shù)據(jù)類型

jscript 有三種->主要數(shù)據(jù)類型、兩種->復(fù)合數(shù)據(jù)類型和兩種->特殊數(shù)據(jù)類型。

主要(基本)數(shù)據(jù)類型

字符串?dāng)?shù)值布爾

復(fù)合(引用)數(shù)據(jù)類型

對象數(shù)組

特殊數(shù)據(jù)類型

 Null`Undefined`

字符串?dāng)?shù)據(jù)類型:字符串?dāng)?shù)據(jù)類型用來表示 JScript 中的文本。在js中,雖然雙引號("")和單引號('')均可表示字符串,而且它們幾乎沒有任何區(qū)別。但只使用雙引號("")來表示字符串被認為是最佳的。

一個字符串值是排在一起的一串零或零以上的 Unicode 字符(字母、數(shù)字和標(biāo)點符號)。

什么是Unicode?

Unicode為每個字符都提供了唯一的數(shù)值,不管是什么平臺、什么程序或什么語言。開發(fā)unicode是為了給處理世界上存在的所有字符提供統(tǒng)一的編碼。

數(shù)值數(shù)據(jù)類型

我們需要明白一點,JScript 內(nèi)部將所有的數(shù)值表示為浮點值,因此,在 Jscript 中整數(shù)和浮點值沒有差別。

Boolean數(shù)據(jù)類型

布爾(邏輯)只能有兩個值:true 或 false。

js數(shù)組和對象

詳情看我這篇文章->javascript學(xué)習(xí)總結(jié)— —數(shù)組和對象部分

Null 數(shù)據(jù)類型:可以通過給一個變量賦 null 值來清除變量的內(nèi)容。

Jscript中 typeof 運算符將報告 null 值為 Object 類型,而非類型 null。

<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
  <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
 <title></title>
 <script type="text/javascript"> 
   alert(typeof null);
 </script>
</head>
<body>
</body>
</html>

null用來表示尚未存在的對象,常用來表示函數(shù)企圖返回一個不存在的對象。

Undefined 數(shù)據(jù)類型:

如下情況將返回 undefined 值:

對象屬性不存在,聲明了變量但從未賦值。

null和undefined的區(qū)別

alert(typeof undefined); //output "undefined" 
alert(typeof null); //output "object" 
alert(null == undefined); //output "true" 

ECMAScript認為undefined是從null派生出來的,所以把它們定義為相等的。

alert(null === undefined); //output "false" 
alert(typeof null == typeof undefined); //output "false" 

null與undefined的類型是不一樣的,所以輸出"false"。而===代表絕對等于,在這里null === undefined輸出false

另外,這里介紹一種比較重要的數(shù)據(jù)類型——引用數(shù)據(jù)類型

引用數(shù)據(jù)類型

javascript引用數(shù)據(jù)類型是保存在堆內(nèi)存中的對象,JavaScript不允許直接訪問堆內(nèi)存空間中的位置和操作堆內(nèi)存空間,只能通過操作對象在棧內(nèi)存中的引用地址。所以引用類型的數(shù)據(jù),在棧內(nèi)存中保存的實際上是對象在堆內(nèi)存中的引用地址。通過這個引用地址可以快速查找到保存在堆內(nèi)存中的對象。

下面我們來演示這個引用數(shù)據(jù)類型賦值過程

自然,給obj2添加name屬性,實際上是給堆內(nèi)存中的對象添加了name屬性,obj2和obj1在棧內(nèi)存中保存的只是堆內(nèi)存對象的引用地址,雖然也是拷貝了一份,但指向的對象卻是同一個。故而改變obj2引起了obj1的改變。

基本類型值指的是那些保存在棧內(nèi)存中的簡單數(shù)據(jù)段,即這種值完全保存在內(nèi)存中的一個位置。

而引用類型值則是指那些保存在堆內(nèi)存中的對象,即變量中保存的實際上只是一個指針,這個指針指向內(nèi)存中的另一個位置,該位置保存對象。

簡而言之,堆內(nèi)存存放引用值,棧內(nèi)存存放固定類型值。

ECMAScript 中,變量可以存在兩種類型的值,即原始值和引用值。
原始值存儲在棧(stack)中的簡單數(shù)據(jù)段,也就是說,它們的值直接存儲在變量訪問的位置。引用值存儲在堆(heap)中的對象,也就是說,存儲在變量處的值是一個指針(point),指向存儲對象的內(nèi)存處。

<script type="text/javascript”>
var box = new Object(); //創(chuàng)建一個引用類型
var box = "lee";  //基本類型值是字符串
box.age = 23;  //基本類型值添加屬性很怪異,因為只有對象才可以添加屬性。
alert(box.age); //不是引用類型,無法輸出;
</script>

3.JScript 的運算符

優(yōu)先級:指運算符的運算順序,通俗的說就是先計算哪一部分。
結(jié)合性:同一優(yōu)先級運算符的計算順序,通俗的說就是從哪個方向算起,是左到右還是右到左。

數(shù)據(jù)類型轉(zhuǎn)換

String() 轉(zhuǎn)換為字符串類型
Number() 轉(zhuǎn)換為數(shù)字類型
Boolean() 轉(zhuǎn)換為布爾類型

parseInt:將字符串轉(zhuǎn)換為整數(shù)。從字符串的開頭開始解析,在第一個非整數(shù)的位置停止解析,并返回前面讀到所有的整數(shù)。如果字符串不是以整數(shù)開頭的,將返回NaN。如:parseInt(“150 hi”)返回的值是:150,parseInt("hi")返回的值是:NaN。
parseFloat:將字符串轉(zhuǎn)換為浮點數(shù)。 從字符串的開頭開始解析,在第一個非整數(shù)的位置停止解析,并返回前面讀到所有的整數(shù)。如果字符串不是以整數(shù)開頭的,將返回NaN。如:parseFloat("15.5 hi") 返回的值是:15.5,parseFloat("hi 15.5")返回的值是:NaN。

eval:將字符串作為javascript表達式進行計算,并返回執(zhí)行結(jié)果,如果沒有結(jié)果則返回undefined。

4.js流程控制

對于js流程控制語句,這里只講幾個比較難懂的。其他不贅述。等下附上一張思維導(dǎo)圖。
1.for...in 語句對應(yīng)于一個對象的每個,或一個數(shù)組的每個元素,執(zhí)行一個或多個語句。

for (variable in [object | array])
statements 

參數(shù):

variable:必選項。一個變量,它可以是 object 的任一屬性或 array 的任一元素。
object, array:可選項。要在其上遍歷的對象或數(shù)組。
statement:可選項。相對于 object 的每個屬性或 array 的每個元素,都要被執(zhí)行的一個或多個語句。可以是復(fù)合語句。

雖然條件控制語句(如if語句)只在執(zhí)行多條語句的情況下才要求使用代碼塊(左花括號"{"開頭,右花括號"}"結(jié)尾),但最佳實踐是始終使用代碼塊。

if(args)
  alert(args);//容易出錯

if(args){
  alert(args);//推薦使用
}


js流程控制語句思維導(dǎo)圖

5.js函數(shù)

函數(shù)是由事件驅(qū)動的或者當(dāng)它被調(diào)用時執(zhí)行的可重復(fù)使用的代碼塊。

Jscript 支持兩種函數(shù):一類是語言內(nèi)部的函數(shù),另一類是自己創(chuàng)建的。
JavaScript 函數(shù)允許沒有參數(shù)(但包含參數(shù)的小括號不能省略),也可以向函數(shù)傳遞參數(shù)供函數(shù)使用。

更多關(guān)于函數(shù)的知識請訪問我的另一篇文章:javascript學(xué)習(xí)大總結(jié)(四)function函數(shù)部分

對象的組成

方法——函數(shù):過程、動態(tài)的
屬性——變量:狀態(tài)、靜態(tài)的

最后,再附上一張前輩總結(jié)的思維導(dǎo)圖:


相關(guān)文章

  • JavaScript中的原型繼承基礎(chǔ)學(xué)習(xí)教程

    JavaScript中的原型繼承基礎(chǔ)學(xué)習(xí)教程

    這篇文章主要介紹了JavaScript中的原型繼承基礎(chǔ)學(xué)習(xí)教程,基于原型prototype的繼承是JavaScript中實現(xiàn)面向?qū)ο笾械睦^承特性的基本手段,需要的朋友可以參考下
    2016-05-05
  • JavaScript中的異步與同步詳解

    JavaScript中的異步與同步詳解

    這篇文章主要介紹了JavaScript中的異步與同步詳解,如果一個線程在一個節(jié)點中添加內(nèi)容,另一個線程要刪除這個節(jié)點,所以為了不必要的麻煩,js就是一門單線程語言,需要的朋友可以參考下
    2023-07-07
  • 詳解JavaScript中Date.UTC()方法的使用

    詳解JavaScript中Date.UTC()方法的使用

    這篇文章主要介紹了詳解JavaScript中Date.UTC()方法的使用,是JS入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-06-06
  • 淺析JavaScript異步代碼優(yōu)化

    淺析JavaScript異步代碼優(yōu)化

    這篇文章主要介紹了JavaScript異步代碼優(yōu)化,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • js實現(xiàn)圖片局部放大效果詳解

    js實現(xiàn)圖片局部放大效果詳解

    這篇文章主要介紹了js實現(xiàn)圖片局部放大效果,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • JavaScript var聲明變量背后的原理示例解析

    JavaScript var聲明變量背后的原理示例解析

    只要是寫過點JS代碼,很簡單一個var 就完事了,那么JS編譯器背后它又發(fā)生了什么呢?在本文將為大家詳細介紹下,感興趣的朋友不要錯過
    2013-10-10
  • javascript對象之內(nèi)置對象Math使用方法

    javascript對象之內(nèi)置對象Math使用方法

    Math對象的一些方法能實現(xiàn)我們課本上的某些數(shù)學(xué)計算,比較常用的方法有如下幾個
    2010-04-04
  • 詳解JavaScript對W3C DOM模版的支持情況

    詳解JavaScript對W3C DOM模版的支持情況

    這篇文章主要介紹了詳解JavaScript對W3C DOM模版的支持情況,在JS前端編程的兼容性方面可作參考使用,需要的朋友可以參考下
    2015-06-06
  • Javascript基礎(chǔ)教程之for循環(huán)

    Javascript基礎(chǔ)教程之for循環(huán)

    這篇文章主要介紹了Javascript基礎(chǔ)教程之for循環(huán)的相關(guān)資料以及示例分享,需要的朋友可以參考下
    2015-01-01
  • 詳解js閉包

    詳解js閉包

    閉包是一個比較抽象的概念,尤其是對js新手來說.書上的解釋實在是比較晦澀,對我來說也是一樣.
    2014-09-09

最新評論