天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

Javascript & DHTML 實例編程(教程)基礎知識

[ 2007-04-11 14:31:50 | Author: never-online ] 
這一節首先請下載JScript.chm這本手冊,無論新手老手,有一本手冊是免不了的,特別是對于新手,如果你沒有空翻犀牛書,那么這本手冊將是你了解這門語言的首選。下面所講的大多數,手冊上可以沒有提及,或提及很少的內容。

以下的教程都是針對你對上面所說的JScript.chm這本手冊了解的基礎上而寫的,如果你還沒有看過JScript.chm,建議你先下載,邊看手冊,邊看教程。

JS的語法與大多數類C的語言差不多的語法,差別只在它本身的特性上面。所以語法的具體內容,我不再多寫,多看看手冊應該明白的。

JS五大對象:String, Number, Boolean, Object, Function。

JS四種循環:
for(var i=0; i<n; i++) {}
do {} while(true);
while(true) {}
for (var i in collection) {}

異常處理:
try {} catch(aVariable){}

JS語法我就不一一列舉了,這里只JS的幾大對象進行一些說明,手冊也許是沒有說到的。

一、字符串。
字符串是最常用的。而強制轉換成字符串的方式至少有幾下兩種:
1、用字符串連接符"+"號。+號在JS里如果是運算就是加,如果是字符串,就是拼接,比如:
<script>
var a_number = 1000
var a_string = a_number + "";
</script>

2、用String強制轉型(String)。
<script>
var a_number = 1000
var a_string = String(a_number);
</script>
在這里要注意一點,上面說的是強制轉型,String前是沒有"new"關鍵字的。如果加上new 關鍵字,那么得到的將是一個String對象。對象可以包含屬性和方法,而字符串不能,以下可以做一個比較:
<script>
var a_number = 1000
var a_string = String(a_number);
a_string.property = "js";
alert(a_string.property) //將提示undefined

var a_object = new String(a_number)
a_object.property = "js";
alert(a_object.property) //將提示js
</script>
所以,有new和沒有new是有區別的。這一點在Number,Boolean里都是如此,所以關于這樣的轉型,在以后中將不再多說。

二、數字(Number)。
這里也說一說轉型的問題。
除了可以用Number來強制轉型外,也可以用parseInt, parseFloat來轉成整型或者浮點型。如果轉型后不是數字,那么,將返回NaN(Not a Number),這個時候可以用isNaN函數來判斷,這里你可以查一下手冊,看看里面的語法。順便記一下這個函數。

三、布爾型(Boolean)。
這一個就較麻煩一些了,因為JS里對它的處理比較奇特。
除了JScript手冊上所說的:“
一個值為 true 或者 false 的表達式。如果需要,非 Boolean 表達式也可以被轉換為 Boolean 值,但是要遵循下列規則: 

所有的對象都被當作 true。 
當且僅當字符串為空時,該字符串被當作 false。 
null 和 undefined 被當作 false。 
當且僅當數字為零時,該數字被當作 false。 
”以外,還應該注意:

首先,在沒有強制轉換成布爾型之前,也就是非true或者也非false的時候
1、在數字條件判斷中,一般情況下就是三種情況:0,負數,正數,只要是非0就是true,下面是示例。
<script>
var a = 0;
var b = -1;
var c = 1;

function assert (aVar) {
if (aVar) alert(true);
else alert(false);
}
assert(a) // false
assert(b) // true
assert(c) // true
</script>
注意:上例中的條件判斷是直接判斷條件語句的,如果我們把條件語句改成:
<script>
var a = 0;
var b = -1;
var c = 1;

function assert (aVar) {
if (aVar==true) alert(true);
else alert(false);
}
assert(a) // false
assert(b) // false
assert(c) // true
</script>
負數會有截然不同的結果。

2、在字符串中,也需要注意
<script>
function assert (aVar) {
if (aVar) alert(true);
else alert(false);
}

var a="undefined";
var b="false";
var c="";

assert(a) // true
assert(b) // true
assert(c) // false
</script>

注意:上例中的條件判斷是直接判斷條件語句的,如果我們把條件語句改成:
<script>
function assert (aVar) {
if (aVar==true) alert(true);
else alert(false);
}

var a="undefined";
var b="false";
var c="";

assert(a) // false
assert(b) // false
assert(c) // false
</script>
也會有截然不同的結果。因此,在處理這方面問題的時候要小心。

也許有些朋友看到這里就會有點暈了,那么怎么樣才能像手冊中所說,只有"",0,null,undefined這些才能是false呢?方法至少有兩種:

(一)、強制轉型:
  1、用上面所說過的Boolean(aVar)來轉型。
  2、用“非運算符”來轉型。比如上例
    <script>
    function assert (aVar) {
    if (!!aVar==true) alert(true);
    else alert(false);
    }

    var a="undefined";
    var b="false";
    var c="";

    assert(a) // true
    assert(b) // true
    assert(c) // false
    </script>
    兩個取反,將aVar轉成Boolean型,相當于Boolean(aVar)。

(二)、全等運算符。
全等運算符是三個等于"===",這與上面所說的不同,它只進行同類型的比較。就上例所說,它只比較的是true或者false,如果與字符串或數字等比,都是false,只有與true相比,才是true。舉例:
<script>
function assert (aVar) {
if (aVar===true) alert(true);
else alert(false);
}

var a="undefined";
var b=true;
var c=1;

assert(a) // false
assert(b) // true
assert(c) // false
</script>

四、對象(Object)。
JS創建對象有至少以下兩種方法:

1、如上所說,用new關鍵字。比如new Number(100),new String("string"),new Object(),new customFunction()等。
這種方法在手冊上有很詳細的說明,這里就不再多說。

2、還可以用花括號括起來。比如
var o = { 
  m1:'never-online.NET',
  m2:'blog' 
}
這種方法就比較省時省力了。利用這種方法來創建對象,需要注意的就是,
每個成員后有一個":"冒號,冒號后是該成員的內容。
其次就是,成員內容后有一個逗號",",但僅最后一個成員是沒有逗號的。

五、函數(Function)。
函數在JS里的作用有兩個,
一是做為一個普通函數一樣被調用。
二是可以做為一個"類"(class)來使用。
第一條就沒有什么可說明的了,手冊上說得很清楚了,第二條就簡要說明一下。
上面第四點里說到對象,除了創建JS本身的對象之外,需要創建一個類的實例,那么就必須先把“類”寫出來。這個類就是Function。
比如:
<script>
function myclass() {
  this.m1="member--m1";
  this.m2="member--m2";
}
var o = new myclass();
</script>

六、關于this和new關鍵字。

也許有些朋友還不太清楚這個this的作用是什么。這是面向對象里所提及的內容

這里也簡單說一下,this就是“自己”的意思,而上面的的“自己”,就是指myclass。
舉個例子來說myclass這個類就是一個模具,模具上有一個名字(m1),還有一個螺絲(m2),而new關鍵字就可以理解成“生產”。那么就可以把上面的代碼理解成:

(模具 myclass)function myclass() {

(模具myclass的名字是)this.m1="member--m1"
(模具myclass上面的螺絲是)this.m2="member--m2";
}

按照模具myclass的樣式生產一個產品o
var o= new myclass();

這個剛出爐的產品就有模具myclass的所有特性了。當然,我們可以按照這個模具的樣式生產成千上萬個。

如果我們愿意,我們還可以修改一下他的屬性,比如,我生產完一個產品,想把他的名字換了。我們也可以這么做

var product = new myclass();
product.m1 = "newProduct"

上面這樣講解,希望能清楚一些。

基本把要說的基礎知識簡單的說了一些,JS的基礎知識其實也有很多,知道有疏忽,但是又不便多寫,寫多了就煩瑣了,只有走一步看一步了,看看還有什么不清楚的,才能再寫出來了 

JavaScript技術Javascript &amp;amp; DHTML 實例編程(教程)基礎知識,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 奇米网一区二区三区在线观看 | 一个人色导航 | 帅小伙和警官同性3p | 欧美eee114| 亚洲国产成人精品无码区5566 | 制服的微热 | bl肉yin荡受np各种play | 日本精品卡一卡2卡3卡四卡三卡 | 为什么丈夫插我我却喜欢被打着插 | 久久婷婷国产五月综合色啪最新 | 久久99精品国产99久久6男男 | 俄罗斯19girl video9| 久久精品国产免费播高清无卡 | 99午夜高清在线视频在观看 | 成人网站国产在线视频内射视频 | 国产成人a视频在线观看 | 亚洲国产欧美在线人成aaaa20 | rio 快播| 久久99精品国产自在自线 | 蜜桃成熟时33D在线嘟嘟网 | jizzjizz3d动漫| 久久综合伊人 | 幺妹视频福利视频 | 国产一区二区免费在线观看 | 亚洲精品久久无码AV片WWW | 一区二区三区四区国产 | 人与禽物videos另类 | 睡觉被偷偷进入magnet | 国产成人aaa在线视频免费观看 | 9亚洲欧洲免费无码在线 | 青草久久精品亚洲综合专区 | 美女被日出水 | 伊人久久大香线蕉综合亚洲 | 超碰免费视频在线观看 | 苍井空小公主qvod | 永久免费在线看mv | 出轨的妻子在线观看 | 国产不卡在线观看视频 | 秋霞电影网午夜免费鲁丝片 | 天美传媒MV高清免费看 | 中文字幕无码A片久久 |