js文件里面如果用到了 在head后面出現(xiàn)的html標(biāo)記 放在head中就有可能提示對象為空的錯(cuò)誤
創(chuàng)新互聯(lián)建站-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比泗洪網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式泗洪網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋泗洪地區(qū)。費(fèi)用合理售后完善,十年實(shí)體公司更值得信賴。
放在文件尾部則不會出現(xiàn)
一個(gè)原則,任何程序中用到的html元素必須在函數(shù)執(zhí)行前已經(jīng)加載到瀏覽器中,只有這個(gè)原則滿足才能談其他的
目前所在這的這個(gè)項(xiàng)目里,我所接手的那部分頁面是結(jié)合使用JSP標(biāo)簽和JavaScript來進(jìn)行初始化的。由于JavaScript在處理JavaBean數(shù)據(jù)時(shí)沒有JSP標(biāo)簽方便,所以是將JavaScript寫在一個(gè)單獨(dú)的JSP頁面中,同時(shí)加入一些JSP標(biāo)簽對JavaScript中的部分代碼根據(jù)JavaBean數(shù)據(jù)來動態(tài)生成。今天早上測試組給出的一個(gè)BUG就是由于初始化錯(cuò)誤產(chǎn)生的,而且在修改這個(gè)BUG的時(shí)候,由于JSP標(biāo)簽和JavaScript混在一起,修改和調(diào)試十分麻煩。我沒有學(xué)過AJAX,雖然我知道JavaScript功能十分強(qiáng)大。不過認(rèn)為在這里,JavaScript被濫用了。JavaScript主要用來在用戶端瀏覽器上與用戶進(jìn)行交互,而在服務(wù)器端,則應(yīng)該由是JSP或者ASP來實(shí)現(xiàn)。這樣才能使程序更加清晰,便于開發(fā)和維護(hù)。所以,我認(rèn)為,對于服務(wù)器端的頁面初始化,也即頁面在服務(wù)器端的動態(tài)生成,還是應(yīng)該使用JSP。當(dāng)然,也可以使用JSP來動態(tài)的生成一些JavaScript代碼。
定義后立即執(zhí)行 相當(dāng)于:
var ff=function(){
。。。
};
fc(c);
c是參數(shù)。
Javascript是一種由Netscape的LiveScript發(fā)展而來的腳本語言,主要目的是為了解決服務(wù)器終端語言,比如Perl,遺留的速度問題。當(dāng)時(shí)服務(wù)端需要對數(shù)據(jù)進(jìn)行驗(yàn)證,由于網(wǎng)絡(luò)速度相當(dāng)緩慢,只有28.8kbps,驗(yàn)證步驟浪費(fèi)的時(shí)間太多。于是Netscape的瀏覽器Navigator加入了Javascript,提供了數(shù)據(jù)驗(yàn)證的基本功能。
歷史
在1992年,Nombas開始開發(fā)一種嵌入式腳本語言,叫做C-minus-minus(Cmm)。[待續(xù)...
能夠具有交互性,能夠包含更多活躍的元素,就有必要在網(wǎng)頁中嵌入其它的技術(shù)。如:Javascript、VBScript、Document Object Model(文件目標(biāo)模塊)、Layers和 Cascading Style Sheets(CSS),這里主要講Javascript。那么Javascript是什么東東?Javascript就是適應(yīng)動態(tài)網(wǎng)頁制作的需要而誕生的一種新的編程語言,如今越來越廣泛地使用于Internet網(wǎng)頁制作上。 Javascript是由 Netscape公司開發(fā)的一種腳本語言(scripting language),或者稱為描述語言。在HTML基礎(chǔ)上,使用Javascript可以開發(fā)交互式Web網(wǎng)頁。Javascript的出現(xiàn)使得網(wǎng)頁和用戶之間實(shí)現(xiàn)了一種實(shí)時(shí)性的、動態(tài)的、交互性的關(guān)系,使網(wǎng)頁包含更多活躍的元素和更加精彩的內(nèi)容。 運(yùn)行用Javascript編寫的程序需要能支持Javascript語言的瀏覽器。Netscape公司 Navigator 3.0以上版本的瀏覽器都能支持 Javascript程序,微軟公司 Internet Explorer 3.0以上版本的瀏覽器基本上支持Javascript。微軟公司還有自己開發(fā)的Javascript,稱為JScript。 Javascript和Jscript基本上是相同的,只是在一些細(xì)節(jié)上有出入。 Javascript短小精悍, 又是在客戶機(jī)上執(zhí)行的,大大提高了網(wǎng)頁的瀏覽速度和交互能力。 同時(shí)它又是專門為制作Web網(wǎng)頁而量身定做的一種簡單的編程語言。
雖然,在Dreamweaver的Behaviors可以為我們方便地使用Javascript程序而不用編寫代碼,但我們自己了解了Javascript的編程方法后,將能更加方便靈活地應(yīng)用,也使Javascript的代碼更簡練。本專題通過對一系列典型程序的剖析,使你快速地掌握J(rèn)avascript的編程技巧,設(shè)計(jì)出質(zhì)量上乘的動態(tài)網(wǎng)頁打下堅(jiān)實(shí)的基礎(chǔ)。在此之前,我們先了解一些Javascript 的基本概念。
JavaScript 有什么特點(diǎn)
JavaScript 使網(wǎng)頁增加互動性。JavaScript 使有規(guī)律地重復(fù)的HTML文段簡化,減少下載時(shí)間。JavaScript 能及時(shí)響應(yīng)用戶的操作,對提交表單做即時(shí)的檢查,無需浪費(fèi)時(shí)間交由 CGI 驗(yàn)證。JavaScript 的特點(diǎn)是無窮無盡的,只要你有創(chuàng)意。
Java 與 JavaScript 有什么不同
很多人看到 Java 和 JavaScript 都有“Java”四個(gè)字,就以為它們是同一樣?xùn)|西,連我自己當(dāng)初也是這樣。其實(shí)它們是完完全全不同的兩種東西。Java,全稱應(yīng)該是 Java Applet,是嵌在網(wǎng)頁中,而又有自己獨(dú)立的運(yùn)行窗口的小程序。Java Applet 是預(yù)先編譯好的,一個(gè) Applet 文件(.class)用 Notepad 打開閱讀,根本不能理解。Java Applet 的功能很強(qiáng)大,可以訪問 http、ftp等協(xié)議,甚至可以在電腦上種病毒(已有先例了)。相比之下,JavaScript 的能力就比較小了。JavaScript 是一種“腳本”(“Script”),它直接把代碼寫到 HTML 文檔中,瀏覽器讀取它們的時(shí)候才進(jìn)行編譯、執(zhí)行,所以能查看 HTML 源文件就能查看JavaScript 源代碼。JavaScript 沒有獨(dú)立的運(yùn)行窗口,瀏覽器當(dāng)前窗口就是它的運(yùn)行窗口。它們的相同點(diǎn),我想只有同是以 Java 作編程語言一點(diǎn)了。
開發(fā) JavaScript 該用什么軟件
一個(gè) JavaScript 程序其實(shí)是一個(gè)文檔,一個(gè)文本文件。它是嵌入到 HTML 文檔中的。所以,任何可以編寫 HTML 文檔的軟件都可以用來開發(fā) JavaScript。在此我推薦大家用 FrontPage 2000 附帶的 Microsoft 腳本編輯器(在 FrontPage 菜單 | 工具 | 宏 | Microsoft 腳本編輯器)。它是個(gè)像 Visual Basic / C++ 一樣的程序開發(fā)器,能對正在輸入的語句作出簡要提示。配合 FrontPage 2000,使工作量大大減少。
一、Javascript在網(wǎng)頁的用法
Javascript加入網(wǎng)頁有兩種方法:
1、直接加入HTML文檔
這是最常用的方法,大部分含有Javascript的網(wǎng)頁都采用這種方法,如:
script language="Javascript"
!--
document.writeln("這是Javascript!采用直接插入的方法!");
//-Javascript結(jié)束--
/script
在這個(gè)例子中,我們可看到一個(gè)新的標(biāo)簽: script……/script,而script language="Javascript” 用來告訴瀏覽器這是用Javascript編寫的程序,需要調(diào)動相應(yīng)的解釋程序進(jìn)行解釋。
HTML的注釋標(biāo)簽!--和--:用來去掉瀏覽器所不能識別的Javascript源代碼的,這對不支持 Javascript 語言的瀏覽器來說是很有用的。
//-Javascript結(jié)束:雙斜杠表示 Javascript的注釋部分,即從//開始到行尾的字符都被忽略。 至于程序中所用到的document.write()函數(shù)則表示將括號中的文字輸出到窗口中去, 這在后面將會詳細(xì)介紹。 另外一點(diǎn)需要注意的是,script……/script的位置并不是固定的,可以包含在head....../head 或body...../body中的任何地方。
2、引用方式 如果已經(jīng)存在一個(gè)Javascript源文件(以js為擴(kuò)展名),則可以采用這種引用的方式,以提高程序代碼的利用率。其基本格式如下:
script src=url language="Javascript"/script
其中的Url就是程序文件的地址。同樣的,這樣的語句可以放在HTML文檔頭部或主體的任何部分。 如果要實(shí)現(xiàn)“直接插入方式”中所舉例子的效果,可以首先創(chuàng)建一個(gè)Javascript源代碼文件“Script.js”,其內(nèi)容如下:
document.writeln("這是Javascript!采用直接插入的方法!");
在網(wǎng)頁中可以這樣調(diào)用程序:script src="Script.js" language="Javascript"/script 。
二、Javascript基本概念
在這里只作簡單介紹,在以后的例子中結(jié)程序再作具體解釋其作用。
1、運(yùn)算符
運(yùn)算符就是完成操和的一系列符號,它有七類:
賦值運(yùn)算符、算術(shù)運(yùn)算符、比較運(yùn)算符、邏輯運(yùn)算符、條件運(yùn)算、位操作運(yùn)算符和字符串運(yùn)算符。
2、表達(dá)式
運(yùn)算符和操作數(shù)的組合稱為表達(dá)式,通常分為四類:賦值表達(dá)式、算術(shù)表達(dá)式、布爾表達(dá)式和字符串表達(dá)式。
3、語句
Javascript程序是由若干語句組成的,語句是編寫程序的指令。Javascript提供了完整的基本編程語句,它們是:
賦值語句、switch選擇語句、while循環(huán)語句、for循環(huán)語句、do while循環(huán)語句、break循環(huán)中止語句和continue循環(huán)中斷語句。
4、函數(shù)
函數(shù)是命名的語句段,這個(gè)語句段可以被當(dāng)作一個(gè)整體來引用不著和執(zhí)行。使用函數(shù)要注意以下幾點(diǎn):
1)函數(shù)由關(guān)鍵字function定義;
2)函數(shù)必須先定義后使用,否則將出錯(cuò);
3)函數(shù)名是調(diào)用函數(shù)時(shí)引用的名稱,它對大小寫是敏感的,調(diào)用函數(shù)時(shí)不可寫錯(cuò)函數(shù)名;
4)參數(shù)表示傳遞給函數(shù)使用或操作的值,它可以是常量,也可以是變量;
5)return語句用于返回表達(dá)式的值,也可以沒有。
5、對象
Javascript的一個(gè)重要功能就是基于對象的功能,通過基于對象的程序設(shè)計(jì),可以用更直觀、模塊化和可重復(fù)使用的方式進(jìn)行程序開發(fā)。
一組包含數(shù)據(jù)的屬性和對屬性中包含數(shù)據(jù)進(jìn)行操作的方法,稱為對象。比如要設(shè)定網(wǎng)頁的背景顏色,所針對的對象就是document,所用的屬性名是bgcolor,如document.bgcolor="blue",就是表示使背景的顏色為藍(lán)色。
6、事件
用戶與網(wǎng)頁交互時(shí)產(chǎn)生的操作,稱為事件。絕大部分事都由用戶的動作所引發(fā),如:用戶按鼠標(biāo)的按鈕,就產(chǎn)生onclick事件,若鼠標(biāo)的指針的鏈接上移動,就產(chǎn)生onmouseover事件等等。在Javascript中,事件往往與事件處理程序配套使用。
學(xué)習(xí)Javascript比較快速有效的方法是先熟悉一些基本概念,然后找?guī)讉€(gè)別人設(shè)計(jì)好的程序認(rèn)真仔細(xì)地分析一遍,再稍作改動,再看看能否達(dá)到預(yù)期目的,不斷地舉一反三,既可以加深對一些參數(shù)、設(shè)計(jì)方法的理解,又可以快速地提高自己的水平。另外,再提醒一下:Javascript對大小寫是敏感的,特別是一些對象、方法、屬性的大小寫一定要一致,要養(yǎng)成一種良好的習(xí)慣,否則在調(diào)試程序時(shí)可要累死你了。
7、變量
如 var myVariable = "some value";
GoodQuestion,一般都放底部。
但在某種情況下也覺得放在頭部比較好,比如一個(gè)給頁面中的某個(gè)元素添加了事件的js腳本。頁面出來了但是js沒加載完的那段時(shí)間,用戶對此元素做事件操作的時(shí)候就出不來應(yīng)該有的效果。
現(xiàn)在比較傾向于放在頭部,做一些優(yōu)化的工作盡量讓js加載快一點(diǎn)。
我想說一下我的看法,關(guān)于JavaScript寫在尾部的。
至于為什么CSS寫在頭部,是因?yàn)闉g覽器預(yù)先加載CSS后,可以不必等待HTML加載完畢就可以開始渲染頁面了。
至于JavaScript寫在尾部,這是因?yàn)镴S主要扮演事件處理的功能。這樣的話,頁面渲染的時(shí)候和JS沒有關(guān)系,放在后面慢慢加載,不要影響更重要的CSS和HTML的加載。
BUT!
但是,現(xiàn)在隨著JS技術(shù)的發(fā)展,JS也開始承擔(dān)起頁面渲染的工作了,比如JQuery UI之類。如果這類JS加載需要很長時(shí)間,就會影響用戶的體驗(yàn),因?yàn)橛脩艨吹降氖且粋€(gè)渲染不完全的界面。
所以,需要把JS區(qū)分看待,承擔(dān)頁面渲染工作的JS和承擔(dān)事件處理的JS要區(qū)分看待。
我的建議是,緩存類似JQuery UI這樣的靜態(tài)文件,剝離渲染頁面的JS和事務(wù)處理的JS。
渲染頁面的JS放在前面,事務(wù)處理的JS放在后面,HTML代碼可以放在兩者中間,或者兩者之前,只要保證DOM加載后能迅速進(jìn)行JS渲染就可以了。