溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

基于組件的機(jī)制的SimpleFramework工作原理是什么

發(fā)布時(shí)間:2021-12-03 10:54:11 來源:億速云 閱讀:131 作者:柒染 欄目:編程語言

本篇文章給大家分享的是有關(guān)基于組件的機(jī)制的SimpleFramework工作原理是什么,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

生命周期:

了解SimpleFramework的生命周期將十分有利于有效地使用 SimpleFramework。這個(gè)生命周期包含如下一些步驟:

應(yīng)用程序的加載

原有的請(qǐng)求及響應(yīng)過程

攔截Respone所生成的HTML

解析XML中的元數(shù)據(jù)

Handle的執(zhí)行

組件渲染

新的HTML響應(yīng)到瀏覽器

應(yīng)用程序的加載

基于SimpleFramework的應(yīng)用程序可通過定義web.xml文件內(nèi)的Filter加載,該文件可載入到任何基于 Java EE 的應(yīng)用服務(wù)器。SimpleFramework同時(shí)提供了一個(gè)Web應(yīng)用程序的入口類,當(dāng)然,這不是必須的,但繼承自AbstractWebApplication可以更快捷的搭建Web應(yīng)用程序。下面是一個(gè)典型的配置示例:

<servlet>     <servlet-name>startup</servlet-name>     <servlet-class>net.simpleframework.web.SimpleWebApplication</servlet-class>     <load-on-startup>0</load-on-startup> </servlet> <filter>     <filter-name>actionFilter</filter-name>     <filter-class<net.simpleframework.web.page.PageFilter</filter-class> </filter> <filter-mapping>     <filter-name>actionFilter</filter-name>     <url-pattern>*.jsp</url-pattern> </filter-mapping> <listener>     <listener-class>net.simpleframework.web.page.PageEventAdapter</listener-class> </listener>

原有的請(qǐng)求及響應(yīng)過程

該請(qǐng)求及響應(yīng)過程,SimpleFramework并沒有參與,所以,從理論上講,是可以兼容任何基于Servlet的框架,比如:Struts、SpringMVC等。

攔截Respone所生成的HTML

當(dāng)響應(yīng)(Respone)流中產(chǎn)生HTML文檔,在還沒有flush到瀏覽器的時(shí)候,SimpleFramework會(huì)接管該HTML文檔,并解析。

解析XML中的元數(shù)據(jù)

SimpleFramework解析請(qǐng)求中含有XML文件的元信息定義,這些信息是SimpleFramework組件的基礎(chǔ)。

Handle的執(zhí)行

如果定義了HandleClass,SimpleFramework則負(fù)責(zé)調(diào)用該Handle,并把結(jié)果送給渲染器。

組件渲染

渲染器(Render)根據(jù)組件的定義及Handle的執(zhí)行結(jié)果,生成對(duì)應(yīng)的HTML或Javascript等瀏覽器元素,以上三個(gè)步驟可詳見組件請(qǐng)求響應(yīng)過程。

新的HTML響應(yīng)到瀏覽器

SimpleFramework把重新組合的HTML推到瀏覽器端。如果,瀏覽器端含有異步請(qǐng)求的腳本,則重復(fù)執(zhí)行如上步驟。

組件請(qǐng)求響應(yīng)過程:

當(dāng)請(qǐng)求發(fā)現(xiàn)有xml描述文件存在時(shí),Simple將獲取該請(qǐng)求資源的元信息和組件定義

Simple對(duì)響應(yīng)(Response)到瀏覽器的HTML進(jìn)行解析(Filter后處理),并產(chǎn)生HTML解析樹

根據(jù)請(qǐng)求資源的元信息,改寫HTML解析樹。請(qǐng)求資源的元信息主要包含以下幾個(gè)方面(屬性):

resourceProvider(資源提供者),定義該請(qǐng)求資源所需的一些基本信息,這些信息將生成HTML所依賴的一些資源及屬性,比如js、樣式、meta標(biāo)簽等,在Simple的缺省資源提供者實(shí)現(xiàn)中,需要依賴propotype.js庫

importJavascript、importCSS,定義請(qǐng)求資源所需的js和css

importPage,導(dǎo)入其它xml描述文件

scriptEval,定義腳本解析規(guī)則,有三個(gè)值:none、first、always,none是不解析腳本,這個(gè)是缺省定義,可以加快請(qǐng)求資源的速度;first是在***次實(shí)例化組件定義時(shí)解析腳本;always是在每次請(qǐng)求時(shí)都要解析腳本,并實(shí)例化組件定義

scriptContent,定義預(yù)執(zhí)行的腳本

handleClass,定義該請(qǐng)求資源所觸發(fā)的后臺(tái)類

根據(jù)請(qǐng)求資源的組件定義,改寫HTML解析樹,主要包含以下幾個(gè)部分:

獲取組件所需要的資源(js、css、jar等),并添加到HTML解析樹或類路徑下(jar庫)

運(yùn)行組件渲染器,渲染器有兩個(gè)核心功能:生成瀏覽器端渲染代碼和調(diào)用接口類(HandleClass)。渲染器有兩個(gè)主要實(shí)現(xiàn),一個(gè)是基于javascript的渲染器,作用是根據(jù)組件定義生成js代碼;一個(gè)是基于HTML的渲染器,作用是根據(jù)組件定義生成HTML代碼并添加到與HTML解析樹綁定的節(jié)點(diǎn)中

如下圖所示

基于組件的機(jī)制的SimpleFramework工作原理是什么

以上就是基于組件的機(jī)制的SimpleFramework工作原理是什么,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI