推薦:XSL基礎教程第一章XSL介紹
XML的樣式表語言XSL比CCS要復雜得多。
CSS:HTML的樣式表語言
由于HTML使用預先確定的標記,因此這些標記的含義都很好理解:<p>元素定義一段,<h1>元素定義一個標題
由于ajax在跨域的訪問上有問題,目前最好的方法是做代理.寫了個代理程序和心得。
為了做ajax的代理,研究了下服務器端的xmlhttp并和客戶端的ajax中的xmlhttp做了個比較,后臺代碼是asp的。
服務器端的xmlhttp也就是asp小偷程序,我把代碼改成了javascript。
1、在服務器端的xmlhttp.Open("GET",url,false)異步必須是關閉的,而客戶端的異步是打開的,這個很好理解。
2、在服務器端的xmlhttp.Responsebody 這里用的是Responsebody而不是ResponseText或ResponseXml,一開始我是用ResponseText,但在函數bytesToBSTR轉換編碼的時候提示錯誤,經過比較發現其他的asp小偷程序里的代碼都是Responsebody,分析后,發現body返回來的是二進制數據而不是像ResponseText或ResponseXml那樣返回字符或dom對象。
ajax的asp代理函數介紹:
send_request(url) ,url為地址
服務器端代碼如下帶自動判斷所有字符編碼,已測試 日語 韓語 繁體:
以下為引用的內容:
<%@LANGUAGE="JAVASCRIPT" CODEPAGE="65001"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>XMLHTTP</title> </head> <%
Server.ScriptTimeout=9999999; function send_request(url) { var codedtext; http_request = Server.CreateObject("Microsoft.XMLHTTP"); http_request.Open("GET",url,false); http_request.Send(null); if (http_request.ReadyState == 4){ //自動判斷編碼開始 var charresult = http_request.ResponseText.match(/CharSet=(\S )\">/i); if (charresult != null){ var Cset = charresult[1]; }else{Cset = "gb2312"}//對獲取不到的網站采用gb2312編碼,可自行更改 //自動判斷編碼結束 codedtext = bytesToBSTR(http_request.Responsebody,Cset); }else{ codedtext = "Erro"; } return(codedtext); }
function bytesToBSTR(body,Cset){ var objstream; objstream = Server.CreateObject("Adodb.Stream"); objstream.Type = 1; objstream.Mode = 3; objstream.Open(); objstream.Write(body); objstream.Position = 0; objstream.Type = 2; objstream.Charset = Cset; bytesToBSTR = objstream.Readtext; objstream.Close; return(bytesToBSTR); }
%> <body> <% Response.Write(send_request("http://www.daum.net")) %> </body> </html>
|
分享:XSL-FO初學者教程:XSL-FO 區域XSL-FO使用矩形框(區域)來顯示輸出。
XSL-FO 區域
XSL格式化模型定義了一系列的矩形(區域)框來顯示輸出。
所有的輸出都會被格式化到這些框中,然后會被顯示或打印到某個目標媒介。