主頁 > 知識庫 > 完成了AJAX樹附原理分析

完成了AJAX樹附原理分析

熱門標簽:澳大利亞城市地圖標注 遼寧銀行智能外呼系統(tǒng) 電銷機器人違法了嗎 辰溪地圖標注 許昌智能電銷機器人公司 海南銀行智能外呼系統(tǒng)商家 姜堰電銷機器人 遼寧正規(guī)電銷機器人 上海浦東騰訊地圖標注位置
首先要糾正一個上篇博文《Rails中的Ajax初體驗》中的一個錯誤:上篇博文中,我說“要在Rails中使用Ajax,局部模板是必須的”,經(jīng)實踐檢驗,是錯誤的,特此更正。實踐是檢驗真理的唯一標準,此言不虛。經(jīng)過項目中真正通過RJS實現(xiàn)AJAX樹,可知,通過使用insert_html、replace_html等輔助方法,可直接操作頁面上的元素,無須使用局部模板。
整個的實現(xiàn)過程還是有點曲折:

之前使用的生成樹結(jié)構(gòu)的頁面,是利用從服務器獲取的所有數(shù)據(jù),通過一系列javascript腳本函數(shù),一次性地生成整個樹結(jié)構(gòu)目錄。這種方式對付系統(tǒng)的功能菜單還游刃有余,但是要生成包含上千條數(shù)據(jù)的樹結(jié)構(gòu)時,客戶端的瀏覽器需要十幾秒鐘才能把整個樹結(jié)構(gòu)建立起來、顯示在頁面上,這對于用戶來說是不可忍受的——其實對于我們開發(fā)者來說,也是不可忍受的。那么一個可行的辦法就是,利用AJAX技術(shù),先顯示樹結(jié)構(gòu)的第一級節(jié)點,當點擊某個節(jié)點時,再從服務器獲取該節(jié)點的子節(jié)點,顯示出來。這樣,每次與服務器交互的數(shù)據(jù)量不大,加快了頁面響應。

一開始我打算利用RAILS中的AJAX機制,配合使用之前那個版本中的javascript函數(shù)。但是那個版本的思路,是基于從服務器獲取的樹結(jié)構(gòu)數(shù)據(jù),通過循環(huán)、遞歸,在服務器端生成好要在客戶端頁面執(zhí)行的一系列javascript函數(shù)調(diào)用,以生成樹結(jié)構(gòu)。至此,還算是比較符合AJAX的思路,但是下一步就大相徑庭了:舊版本的是將生成的那一大串javascript函數(shù)調(diào)用的字符串,一次性地完全返回給客戶端頁面,客戶端頁面在加載前,已經(jīng)獲得了這一大串字符串,只需簡單地把它加載,就一次性的執(zhí)行它、生成樹結(jié)構(gòu)了。這種方式,等于沒有給AJAX留下插足的任何機會。

此路不通,于是我轉(zhuǎn)而尋找網(wǎng)上別人做的AJAX樹,試圖將其移植過來,為我所用。之前就找到過一個.NET版的,用C#寫的,還沒仔細看過。于是打開VS2005,建好了ASPX工程,研究了一下這個.NET版的AJAX樹。這個版本自帶了一個ACCESS數(shù)據(jù)庫,里面有一些演示數(shù)據(jù)。把IIS架起來后,運行得還真挺順暢。這個AJAX樹的功能做得還挺強,可以實現(xiàn)在頁面上對樹節(jié)點的添加、刪除、編輯、拖拽移動操作。代碼也比較清晰:一個htm頁面和一個aspx頁面,其中aspx頁面中定義了一些服務器端函數(shù),組織出相應的要返回給htm頁面的html代碼段。然而,要把這個移植過來也不容易,首先是對其生成html代碼段的思路不熟悉,不好控制,另外一點,它是通過response.write返回所生成的html代碼段,與RJS中直接指定頁面元素進行控制的思路又不一樣。

也是由于通過對以上兩種方式的探索,使得我對做AJAX樹的思路更加清晰的原因吧,我最終決定還是自己動手,完全自己做一個RAILS下的出來吧。盡管最終從核心內(nèi)容到細節(jié)控制,總算是把這棵樹給搗騰出來了,但中間遇到幾個問題,有的不知道是否RAILS本身就不支持,還有的明明書上、別人都行得通,但我這就是不行。不知個中緣由,列在這里,若有人能夠解答,還望不吝賜教!謝過先!

問題一:用RJS的insert_html輔助方法,無法在一個table最后添加一行(即tr>),即使寫一個簡單的測試程序也不行。最后,我是用div和span做容器,向其中添加table來解決的,即樹的每個節(jié)點都用一個只有一行的table來裝載。

問題二:在使用RJS時,在“render :update”代碼段,只能是單純的一句調(diào)用輔助方法的語句,其它的,無論是加點if判斷,還是再使用另外一個輔助方法,代碼全都失效。本想先用insert_html添加元素,再用call調(diào)用javascript函數(shù)之類,完全行不通,最終是預先在要插入元素的地方放置一個空的容器,然后換用replace_html,將容器中的空內(nèi)容“換”成返回的html代碼段,也達到了添加頁面元素的效果。

問題三:這個是最為奇怪的問題了。當我組合待返回的html元素的代碼時,由于該元素還要繼續(xù)帶有AJAX鏈接,故本想用“#{}”將Ruby代碼嵌入——這種方法理論上講是可行的,可我在實際操作中,記得好像只成功了一兩次,基本上都實現(xiàn)不了AJAX效果(實際上是沒效果)。無奈之下,我根據(jù)頁面初始顯示的第一級樹節(jié)點,查看了頁面代碼,看到了生成的AJAX代碼,再依照它的樣子,替換掉我本來想用Ruby代碼的部分——也就是說,我最終不是用嵌入的Ruby代碼,而是直接寫出將要生成的AJAX代碼——這樣的代碼是多么的丑陋?。?

不過,整個過程下來,還是略有一些可以總結(jié)的東西:

總結(jié)一:由于樹節(jié)點中要顯示的文本中,有的會有加號“+”,而恰巧該文本還是要向服務器發(fā)送的參數(shù),這種情況下,在組合要返回的html代碼段時,加號會被當作連接字符串的操作,那么在必要的地方,則把加號替換成其它不會被誤解的符號,如下劃線“_”,而在傳給數(shù)據(jù)庫做查詢用時,再替換回來。Ruby中將字符串中的模式替換成指定內(nèi)容的函數(shù)是gsub,如:str.gsub("+","_"),就是把str中的加號替換成下劃線。該函數(shù)的第一個參數(shù)也可以是正則表達式。

總結(jié)二:對于頁面上要顯示的每一個樹節(jié)點,都用一個只有一行的table來控制,這樣做有一個好處,就是每個節(jié)點都可以獨立地控制顯示位置,而不用考慮colspan屬性,只需在前面添加指定個數(shù)的td即可,具體做法見“總結(jié)三”。

總結(jié)三(控制樹節(jié)點的顯示級別位置的方法):點擊樹節(jié)點,向服務器發(fā)送該節(jié)點的ID,從而獲取該節(jié)點的子節(jié)點。與此同時,還要返回一個本節(jié)點的級別(頁面初始顯示的第一級節(jié)點的級別為0)。在生成子節(jié)點的html代碼段時,得到父節(jié)點的級別,加上1,即為子節(jié)點的級別。根據(jù)級別數(shù)做循環(huán),向包含子節(jié)點內(nèi)容的table中添加相應個數(shù)的td。在所添加的td中,填入若干空格(nbsp;)(數(shù)量自定,一般2~3個為宜),但是空格只有與td配合使用效果才好,否則容易錯位?;蛘呤孪扔脀indows的畫圖工具做一個白色小方塊的bmp文件(方塊大小根據(jù)已有的在樹的節(jié)點前面表示展開、收攏節(jié)點的圖片設(shè)定),然后在td中嵌入這個小方塊圖片也行。如某個二級節(jié)點,其html代碼段為:table>tr>td>nbsp;nbsp;/td>td>二級節(jié)點/td>/tr>/table>。
您可能感興趣的文章:
  • ajax 技術(shù)和原理分析
  • 談談Ajax原理實現(xiàn)過程
  • Ajax的內(nèi)部實現(xiàn)機制、原理與實踐小結(jié)
  • Ajax工作原理深入理解
  • jquery的ajax跨域請求原理和示例
  • ajax 文件上傳應用簡單實現(xiàn)
  • Ajax方式提交帶文件上傳的表單及隱藏iframe應用
  • Ajax+asp應用實例 注冊模塊,表單提交
  • AngularJS入門教程之與服務器(Ajax)交互操作示例【附完整demo源碼下載】
  • Ajax PHP簡單入門教程代碼
  • Ajax原理與應用案例快速入門教程

標簽:西藏 威海 深圳 銅川 伊春 晉城 撫州 崇左

巨人網(wǎng)絡(luò)通訊聲明:本文標題《完成了AJAX樹附原理分析》,本文關(guān)鍵詞  完,成了,AJAX,樹附,原理,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《完成了AJAX樹附原理分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于完成了AJAX樹附原理分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章