中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)絡(luò)編程 > 模板用xml的思路
用php讀取xml數(shù)據(jù) 回到列表 多表查詢技巧
 模板用xml的思路

作者:5do8 時間: 2006-03-22 文檔類型:原創(chuàng) 來自:藍色理想

第 1 頁 模板用xml的思路 [1]
第 2 頁 模板用xml的思路 [2]

前段時間,一直比較關(guān)心php的模板技術(shù)的我,接到了客戶的要求:全站利用模板技術(shù),可以控制多模板,這個項目要求有強大的后臺,主要是多模板,難點就在模板的導(dǎo)入和識別并且生成上,我仔細考察了php的模板核心技術(shù),無外乎查找字符串開始,然后定義替換變量,替換成數(shù)據(jù),然后并成輸出頁輸出,牽扯到的緩存我就不再說了.

我們來看看這種方式的生成方式的缺點:如果要"多樣式"的顯示數(shù)據(jù),當然我先不說CSS,不能真正的把數(shù)據(jù)和表示分離,無外乎利用css樣式表方式顯示而已,我們現(xiàn)在接到的這個項目不但要求css樣式表的可選化,而且要求數(shù)據(jù)顯示的"多方式",打個比方,看下圖:

我們下面為了容易描述期間,我這樣表示各個部分:A,B,C,D,E,F,G這6個區(qū)可以表示數(shù)據(jù)顯示區(qū)域,從設(shè)計者角度考慮,有全局(div控制A-G),TOP(A),LEFT(B),RIGHT(C,D,E,F)和FOOTER(G),當然,您可以分的更細一些,這么顯示,可以用div控制的,但這不是模板技術(shù),請明白,多樣式表不叫模板,這和模板無關(guān),所謂的模板,就是只與"數(shù)據(jù)布局"相關(guān),在A數(shù)據(jù)我們另外可以表示成一個導(dǎo)航,如果您喜歡的話.這在傳統(tǒng)的模板技術(shù)中會這樣寫:

...
<div id="top">
{$SITE_TOP$}//cjjer制作
</div>
...

替換的時候replace()的是{$ 和$}符號中的變量,這在數(shù)據(jù)簡單的時候,比方只是一個導(dǎo)航,而我們?nèi)绻氖且粋很復(fù)雜的數(shù)據(jù)顯示的時候,那就很難控制了,因為把一個很大量輸出數(shù)據(jù)放在一個變量中很難保證不出錯.

另外,傳統(tǒng)的模板(在php中)是這樣的,獲取模板的文件,加載,顯示,這沒什么問題,問題就在當web項目(不完全是網(wǎng)站)非常復(fù)雜的時候,很容易替換錯誤和模板單調(diào),雖然可以用css控制一些顯示,但很難控制數(shù)據(jù)的布局,比方,E區(qū)我今天不想要了,你改模板,重新加載文件... ?

有沒有更加容易的解決方案?有.

我提出了這樣一種觀點:

模板頁為 XML文檔 ,模板節(jié)點加載已有模塊 ,加載"仿xml數(shù)據(jù)"生成文件 (原諒我,這么說我覺得已經(jīng)非常容易了)下面我就這種模板技術(shù)詳談.

先看看我說的模塊是什么東西,大家都知道,html中的<div>呀,<table>都是顯示數(shù)據(jù)布局的一些布局標簽,為什么我們不能自己制作這種標簽?zāi)?例如:我現(xiàn)在"創(chuàng)"一個這樣的標簽<format>這里,當然,這個標簽對項目是有意義的,表示控制全局的模塊節(jié)點,如果在模板頁中出現(xiàn)節(jié)點<format>加載的就是對應(yīng)名稱為 format 的模塊數(shù)據(jù):

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3c.org/TR/1999/REC-html401-19991224/loose.dtd">
<HTML xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>[%TITLE%]</title>
<meta http-equiv="content-type" content="text/html; charset=gb2312" />
<meta http-equiv="Content-Language" content="zh-CN" />
<meta name="author" content="[%AUTHOR%]" />
<meta name="copyright" content="[%COPYRIGHT%]" />
<meta name="description" content="[%DESCRIPTION%]" />
<meta name="keywords" content="[%KEYWORDS%]" />
<link href="styles/[%STYLES%]/import.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="format">
&%format%&
</div>
</body>
</html>

這里我把這個模板節(jié)點定義成 加載控制全局的html源了,再看這個標簽topdata:

<div id="topdata">{%TOP_MESS%}<%=show_top_meun()%></div>

如果這個節(jié)點被加載,生成的文件里面會將topdata節(jié)點替換成如上的html文檔模板,這就是模塊

這里的模塊也可以是xml文檔,重復(fù)加載模塊,也可以是終數(shù)據(jù).

當這些還有模塊節(jié)點的xml模板被加載以后,就被程序識別,對應(yīng)的加載成html二級模塊,然后提出我們的"仿xml 數(shù)據(jù)"標記中的數(shù)據(jù),正則替換對應(yīng)的節(jié)點,生成文件,這里的"仿xml數(shù)據(jù)"是這種方式的數(shù)據(jù):

{%TITLE%}<%=cjjer_hometitle%>{%/TITLE%}
{%STYLE%}default{%/STYLE%}
{%site_top%}<%=get_cache(0)%>{%/site_top%}
{%format_two%}<div id="footer_ul"><%Call light()%></div>
{%/format_two%}
{%site_footer%}<%Call cc_footer()%>{%/site_footer%}

這里,您可能馬上理解了我說的"仿xml數(shù)據(jù)"了,這種加載數(shù)據(jù)的方式也是xml分析節(jié)點,然后直接正則替換,當然可以include文件的(asp,php).

好了,現(xiàn)在您想必概念已經(jīng)很清楚了,(不清楚的話重新看上面的話,或看如下的例子)

我就舉個舉個簡單的例子說明一下(format_index.xml):

<format>
<site_top>{%site_top%}</site_top>
<format_two>
<home_bigflash>{%home_bigflash%}</home_bigflash>
{%format_two%}
</format_two>
<site_footer>{%site_footer%}</site_footer>
</format>

模塊:

//format,就是最上面的那個,不列舉了

//home_bigflash

<div id="main_img">
  <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/
swflash.cab#version=6,0,29,0" width="100%">
<param name="movie" value="images/main.swf">
<param name="wmode" value="transparent">
<param name="quality" value="high">
<embed src="images/main.swf" quality="high" pluginspage="http://www.macromedia.com/go/getflashplayer" type="application/x-shockwave-flash" width="100%"></embed>
</object>
</div>

//format_two
<div id="format_two">(&format_two&)<script language="javascript" type="text/javascript" src="js/same_h2.js"></script> </div>

//site_footer
<div id="site_footer">(&site_footer&)</div>

差不多應(yīng)該加載的模板和模塊就這點吧(都是可以重用的.)

出處:藍色理想
責任編輯:moby

上一頁 下一頁 模板用xml的思路 [2]

◎進入論壇網(wǎng)絡(luò)編程版塊參加討論

相關(guān)文章 更多相關(guān)鏈接
用php讀取xml數(shù)據(jù)
xml css htc 的綜合運用
js“樹”讀取xml數(shù)據(jù)
xmlHTTP返回值重編碼的優(yōu)化
[xml] xml ,xsl,css 之亂搞
作者文章 更多作者文章
玩轉(zhuǎn)圖像函數(shù)庫—常見圖形操作
asp編譯成dll-圖形化教程
實戰(zhàn)access+php的留言版
[php]配置,鏈接access數(shù)據(jù)庫
對ASP用戶的一點建議
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:1/21個記錄/頁 轉(zhuǎn)到 頁 共2個記錄

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2