eclipse+spket+extjs4.1開發環境搭建和代碼智能提示

來源:互聯網
上載者:User

搭建開發環境,首先要準備好幾樣東西:eclipse,tomcat,extjs4.1,還有spket,大家去相關網站下載,都去官網,既可以防止有毒又是最新版。這裡提一下spket的下載。spket的下載網站是:

http://www.spket.com/

點擊右上方的Downloads進入下載頁面,這個產品是個人使用免費,商業用途收費的,大家看著用。這裡是作為eclipse的外掛程式使用,按Plugin進入下載頁面把他下載下來。解壓,把裡面eclipse檔案夾下面的features和plugins複製到eclipse根目錄下與這兩個同名的檔案覆蓋,重啟eclipse,然後Window=>Preferences,看到左邊有spket選項證明你安裝成功了。

        繼續剛才的視窗:

點擊左邊選項的Spket

=>JavaScript Profiles

=>右邊的按鈕中點New

=>Name裡面輸入  ExtJS (這個名字隨意)

=>OK

=>選中ExtJS

=>Add Library

=>Library下拉選項中選中ExtJS

=>OK

=>選中剛才建立的那個ExtJS

=>Add File

=>選中在系統另一個地方解壓的ExtJS包的跟目錄下的build下的sdk.jsb3(這個檔案錯誤很多,在下一篇文章我會說明修改的方法,暫且先這樣用著)

=>然後會出現很多選擇框讓你選擇要哪些提示,我全勾了

=>然後按根節點的ExtJS(注意是最根部的那個ExtJS)

=>點擊右面的按鈕Default(這步很重要,不按他就不會自動提示了)

=>OK退出

        現在是讓spket作為javascript的預設編輯器:

Window

=>Preferences

=>General

=>Editors

=>File Associations

=>右面的File types選中*.js

=>下面的Associated editors選中Spket javascript Editor

=>按右面的按鈕Default

=>OK退出

然後你看到js檔案的表徵圖變成就代表你成功了。

 

怎麼建立一個ExtJS的工程呢,我先示範一下如何做一個HelloWord的。

建立一個工程(動態網頁,eclipse中是Dynamic Web Project),先不要引入ExtJS包,

右鍵工程表徵圖

=>Properties

=>Resource

=>Text file encoding

=>Other

=>UTF-8

=>左邊選Builders

=>去掉JavaScript Validation和Validation前面的勾

=>OK退出

還不能匯入ExtJS包,這樣會卡死eclipse的。去到工程根目錄下,找到.project,用記事本開啟,把兩處刪除掉:

 

第一處:

 

<buildCommand>

        <name>org.eclipse.wst.jsdt.core.javascriptValidator</name>

        <arguments>

        </arguments>

</buildCommand>

第二處:

 

<nature>org.eclipse.wst.jsdt.core.jsNature</nature>

 

儲存退出,refresh一下工程。再把ext包複製進工程,我現在是把整個複製進來,具體怎樣才是最小的發行包大家可以參照網上的各種資料,我也是初學,不是太清楚。

運行根目錄下的index.html(部署可能需要一段時間),能到首頁說明你成功了。具體的代碼提示我會在下一篇文章介紹。

 如果大家照著上面的文章做並且有興趣做了第一個ExtJS程式的話,你會發現代碼提示真的很少,連Ext.onReady和Ext.create都沒有提示。其實不是spket的錯,是ext自己做錯了。Ext根目錄下面的sdk.jsb3一大堆的都是錯誤,而這個正是我們的智能提示要引入的檔案,那智能提示當然有錯誤了。

        用js的編輯器開啟這個檔案,我用了dreamweaver開啟。你把裡面涉及到目錄的重頭到尾略略地看一次再比較真實的目錄,你就知道目錄錯了。錯誤的是基本上所有的目錄。錯誤大概有幾種類型:

pkgs/xxx應該是../pkgs/xxx

../platform/core/xxx應該是../src/core/xxx

../platform/src/xxx應該是../src/xxx

src/xxx應該是../src/xxx

還有其他的相對目錄都漏了../

 

經過觀察,大家想必也知道解決方案了。只是第二個和第三個錯了,其他都是漏了../。但是要修改起來很麻煩,怎麼辦呢?我們可以把檔案放在上一級目錄下面(ExtJS根目錄),看,第一個、第四個和第五個問題都解決了。那隻要把第二個和第三個替換掉就行了。但是替換要講一點技巧,要把前面的盡量多的字都打進去,才能避免把其他的都替換了。綜上,可以這樣替換:

把 "path": "../platform/core/  替換成 "path": "src/core/

把 "path": "../platform/src/  替換成 "path": "src/

替換的字最好是自己複製檔案的,要是這裡的變成了中文符號我就不負責了。

再找到以下代碼:

       {

           "src":"../platform/src/",

           "dest":"src"

       },

       {

           "src":"../platform/core/",

           "dest":"src/core"

       },

替換成

       {

           "src":"src/",

           "dest":"src"

       },

       {

           "src":"src/core/",

           "dest":"src/core"

       },

替換了以後把這個檔案放在Ext根目錄下面,就是上一級目錄,然後開啟eclipse,把ext的提示檔案換成這個sdk.jsb3檔案,所有勾都可以打上。然後開啟一個新的JS檔案,輸入以下代碼(為了實驗代碼是否有自動提示,建議手打):

(function(){

        Ext.onReady(function(){

                  Ext.define("person",{

                           extend:"Ext.data.Model",

                           fields:[

                                    {name:"name",type:"auto"},

                                    {name:"age",type:"int"},

                                    {name:"email",type:"auto"}

                           ]

                  });

                  var p = Ext.create("person",{

                           name:"水山清風",

                           age:22,

                           email:"1112@1112.com"

                  });

                  Ext.MessageBox.alert("用define建立的Model","姓名:" + p.get("name") +"<br/>年齡:" + p.get("age") +"<br/>郵箱:" + p.get("email"));

        });

})();

你會發現 Ext.onReady和 Ext.create都有提示了。而 Ext.data.Model 你可以先輸入再加引號,那樣也有提示了,順帶一提,屬性名稱 field 和 extend也是有提示的。如果你不確定自己輸入的屬性名稱對不對,可以在加了引號之後按住ctrl鍵滑鼠移到最後一級名字那裡看看(例如Ext.data.Model中的Model)看是不是變色並且有底線了,如果有就代表有這個類。你也可以在按住ctrl的情況下按一下滑鼠跳到這個類的js檔案那裡。然後在另一個html檔案裡引入extjs-4.1.0/resources/css/ext-all.css
和 extjs-4.1.0/bootstrap.js (相對目錄根據自己的目錄路徑改變)一級這個js檔案,就可以在頁面看到效果了:

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.