分享
 
 
 

ASP 3.0高级编程(四十五)

王朝asp·作者佚名  2006-12-16
窄屏简体版  字體: |||超大  

异步执行是指在后台检索数据,可以在全部数据返回之前在Web页面上使用已经得到的数据。虽然可能需要的是全部的数据,但异步工作至少可提前开始处理数据。也可让用户先看到某些内容,这使得Web站点看上去响应能力更强。

与TDC类似,RDS数据控件可以通过设置OBJECT标记的参数或编写代码来设置其属性。下面举一个例子:

<OBJECT CLASSID="clsid:BD96C556-65A3-11D0-983A-00C04FC29E33"

ID="dsoAuthors" WIDTH="0" HEIGHT="0">

<PARAM NAME="Connect" VALUE="DSN=pubs">

<PARAM NAME="Server" VALUE="W2000">

<PARAM NAME="SQL" VALUE="SELECT * FROM Authors">

</OBJECT>

等效于:

<OBJECT CLASSID="clsid:BD96C556-65A3-11D0-983A-00C04FC29E33"

ID="dsoAuthors" WIDTH="0" HEIGHT="0">

</OBJECT>

<SCRIPT LANGUAGE=JScript>

function window.onload()

{

dsoAuthors.Connect = "DSN=pubs";

dsoAuthors.Server = "W2000";

dsoAuthors.SQL = "SELECT * FROM Authors";

dsoAuthors.Refresh();

}

</SCRIPT>

这里为Connect参数使用了一个DSN,因为这非常适合该页面,但也可以是任何有效的ADO连接字符串。

URL是ADO 2.5版提供的新特性,允许使用一个文件作为数据源。该文件可以有两种格式:一种是用Recordset.Save方法保存的记录集;另一种是一个ASP页面,它创建一个记录集,然后将其保存在一个流中。代码如下:

<OBJECT CLASSID="clsid:BD96C556-65A3-11D0-983A-00C04FC29E33"

ID="dsoAuthors" WIDTH="0" HEIGHT="0">

<PARAM NAME="URL" VALUE="DataPage.asp">

</OBJECT>

文件DataPage.asp包含以下VBScript代码:

<%

Dim rsData

Set rsData = Server.CreateObject("ADODB.Recordset")

rsData.Open "SELECT * FROM Authors", strConn

rsData.Save Response, adPersistXML

rsData.Close

Set rsData = Nothing

%>

这只是创建了一个记录集,然后用Save方法将记录集以XML格式保存到Response对象中。在ADO的早期版本中,只能将记录集存为物理文件,而ADO 2.5版本能够直接将其存为流。这个ASP页面的结果就是XML格式的记录集。下一章将研究关于流和XML数据的所有主题。

使用URL属性优于使用Connect和SQL属性,其最大优点是:在用户可以看到的网页中不会出现连接的细节。考虑下面的对象定义:

<OBJECT CLASSID="clsid: BD96C556-65A3-11D0-983A-00C04FC29E33"

ID="dsoAuthors" WIDTH="0" HIGHT="0">

<PARAM NAME="Connect" VALUE="DSN=pubs">

<PARAM NAME="Server" VALUE="W2000">

<PARAM NAME="SQL" VALUE="SELECT * FROM Authors">

</OBJECT>

第一行显示了连接的细节。此时能够看到DSN为pubs,并且我们选择了authors表的全部列。这无疑为电脑黑客进入Web站点提供了潜在的路径,因为他们知道了服务器的名称以及数据库的一些细节。现在,考虑一下使用URL属性的情况:

<OBJECT CLASSID="clsid: BD96C556-65A3-11D0-983A-00C04FC29E33"

ID="dsoAuthors" WIDTH="0" HIGHT="0">

<PARAM NAME="URL" VALUE="DataPage.asp">

</OBJECT>

现在,用户所见到的是一个ASP网页的URL地址,没有任何有关服务器和数据库的详细信息。

使用CONNECT/SQL属性的方法,用户可以清楚地见到连接的细节,而使用URL所见的却是数据。从这一点上来说,消除了一个安全问题。

在脚本中设置RDS数据控件的属性时,必须使用Refesh方法,如下所示:

<SCRIPT LANGUAGE=JScript>

function window.onload()

{

dsoAuthors.URL="DataPage.asp";

dosAuthors.Refresh();

}

</SCRIPT>

这将强迫数据控件使用新的属性值,并重新从数据提供者那里检索数据。除了Refresh方法外,RDS数据控件还有许多其他方法方 法

说 明

Cancel

取消任何异步操作

CancelUpdate

取消对数据的任何修改

CreateRecordset

创建一个空的记录集,这允许在本地创建新的数据集

MoveFirst

移到第一条记录

MoveLast

移到最后一条记录

MoveNext

移到下一条记录

MovePrevious

移到上一条记录

Refresh

更新来自数据存储的数据

Reset

应用过滤或排序条件

SubmitChanges

将所有未解决的修改送回数据存储

在本章后面,会见到大多数方法的使用情况。

||||||3. MSHTML数据控件

微软HTML(MSHTML)数据控件比较特别的地方在于:MSHTML是IE的一个组成部分,并能提供一个基于HTML文档的数据源。虽然本质上MSHTML并不是为数据存储使用的一种格式,但如果确实有许多包含某些数据格式的HTML网页,MSHTML可能会变得较为有用。

使用这个控件的代码如下所示:

<OBJECT ID="dsoAuthors" DATA="Authors.html" HIGHT="0" WIDTH="0">

</OBJECT>

为了能使用这个控件,必须为HTML标记指定ID属性,因为正是ID属性确定了字段的名称。例如:

<DIV ID="au_id">172-32-1176</DIV>

<SPAN ID="au_lname">White</SPAN>

<H1 ID="au_fname">Bob</H1>

<PRE ID="au_id">213-46-8915</PRE>

<H2 ID="au_lname">Green</H2>

<H1 ID="au_fname">Cheryl</H1>

读者会注意到这看起来不太漂亮。是的,但正是这样才可以说明HTML标记的名称是无关紧要的,ID才是重要的。使用MSHTML DSO解析时,上面的HTML脚本将会产生两行数据,每一行有三个字段。最后会得到类似于表10-4的数据:

表10-4 HTML脚本产生的数据

au_id

au_lname

au_fname

172-32-1176

White

Bob

213-46-8915

Green

Cheryl

字段是由ID属性确定的。如果一个标记的ID与现有的ID相同,那么这个标记的数据将成为新的一行,否则在相同的行中创建一个新的字段。

与已经讨论过的数据控件类似,MSHTML数据控件有一个Recordset属性,这也是该控件的唯一的一个属性。MSHTML数据控件没有方法。

4. XML数据控件

我们已经知道了一种将XML数据放入RDS控件的方法,即使用RDS数据控件和URL属性从ASP文件中获取XML数据。另外一种方法是使用XML Data Island(XML数据岛),这需要使用XML标记。在这里简要地提一下这个问题,因为在下一章会讨论处理XML数据的细节。

<XML>标记是一个与数据控件功能相似的浏览器HTML标记。在许多情况下与使用一个RDS数据控件类似,但该标记是为处理XML数据而特别设计的。使用的方式有二种。

第一种是使用SRC属性来指定数据的位置。

<XML ID="dsoAuthors" SRC="Authors.xml"></XML>

这表示使用文件Authors.xml作为数据源。

另外,也可在标记中嵌入XML。

<XML ID="dsoAuthors">

<Authors>

<Author>

<au_id>172-32-1176</au_id>

<au_lname>White</au_lname>

<au_fname>Johnson</au_fname>

<phone>408 496-7223</phone>

<contract>True</contract>

</Author>

<Author>

<au_id>213-46-8915</au_id>

<au_lname>Green</au_lname>

<au_fname>Marjorie</au_fname>

<phone>415 986-7020</phone>

<contract>True</contract>

</Author>

</Authors>

</XML>

我们将在下一章详细讨论XML数据控件。

10.2.5 数据绑定

迄今为止,已经可以用几个不同的RDS数据控件将数据送到客户端,但还没有介绍当数据到达客户端后,如何处理数据。实际上,这些数据控件负责的是数据的存储及管理,并不真正地显示数据。因此,问题在于如何将数据从数据控件中取出,并将其提供给HTML元素,使用户能够见到数据。

使用客户端数据最简单的方法是将数据与HTML标记绑定。绑定就是在HTML元素和数据控件之间建立一种联系。数据控件主要负责管理数据,并为HTML元素提供数据,而HTML元素则将数据显示在屏幕上。

为了将数据源与HTML元素绑定,需要设置两个属性:

· DATASRC,确定包含数据的数据控件。在数据源名称前总是要加一个“#”。

· DATAFLD,确定绑定数据控件中的哪个字段。这些字段是数据控件管理的数据中的列名。因此对于一个数据库,就是表中的列名。

例如:

<OBJECT CLASSID="clsid: BD96C556-65A3-11D0-983A-00C04FC29E33"

ID="dsoAuthors" WIDTH="0" HIGHT="0">

<PARAM NAME="URL" VALUE="DataPage.asp">

</OBJECT>

<DIV DATASRC="#dsoAuthors" DATAFLD="au_fname"></DIV>

<DIV DATASCR="#dosAuthors" DATAFLD="au_lname"></DIV>

这里,dsoAuthors是一个标准的RDS数据控件。我们创建了两个DIV元素,并通过设置属性DATASRC指向先前定义的数据控件。然后设置属性DATAFLD为字段名,在本例中为au_fname和au_lname。这就是数据绑定的全部过程。

需要记住一个重要事情是文本输出(Johnson和White)根本没有在HTML脚本中出现。实际上HTML只由以上显示的内容组成。

因此,数据绑定就是数据控件管理远程数据源的数据,同时HTML元素使用该数据并将其显示在屏幕上的能力。

除此之外,HTML元素还有第三个属性:DATAFORMATAS,可以是HTML或TEXT,表示如何格式化字段中的数据。缺省为TEXT,但如果需要HTML格式的数据,可以通过数据绑定将其格式化,例如下面的文本文件。

Description,Image

The main Wrox logo,<IMG SRC="logos/WroxLogo.gif">

The Wrox Conferences logo,<IMG SRC="logos/WroxConferencesLogo.gif">

The ASPToday logo,<IMG SRC="logos/ASPTodayLogo.gif">

这是TDC的源文件,并且包含两个字段,第一个是说明,第二个是显示某些图像的HTML文本。现在把它和一个HTML表格进行绑定。

<TABLE ID="tblData" DATASRC="#dsoLogos">

<THEAD>

<TR>

<TD>Description</TD>

<TD>Image</TD>

</TR>

</THEAD>

<TBODY>

<TR>

<TD><SPAN DATAFLD="Description"></SPAN></TD>

<TD><SPAN DATAFLD="Image"></SPAN></TD>

</TR>

</TBODY>

</TABLE>

这里不必为数据绑定担心,本例介绍的是表格数据绑定,下面将详细讨论这方面的内容。在这里使用是因为能较好地说明格式化数据。

在浏览器中打开它

可以看到数据文件中的三行数据全部显示在浏览器中,但是HTML作为文本显示。为了见到HTML格式的数据,需要使用属性DATAFORMATAS。

<TD><SPAN DATAFLD="Description"></SPAN></TD>

<TD><SPAN DATAFLD="Image" DATAFORMATAS="HTML"></SPAN></TD>

此时在浏览器打开它,会得到一个效果较好的HTML页面

将第二个字段格式化为HTML文档,这一事实说明了字段任何HTML标记都可以解释成为HTML文档。因此,IMG标记变为真正的图像,而源文件中并不包含任何IMG标记,只有绑定的数据。

可以为任一数据源中的字段使用这种格式,任何HTML标记都会被解释。这对于那些允许用户输入格式化文本的情形是比较有利的。

1. 支持数据绑定的元素

在上面的例子,使用了<SPAN>、<DIV>和<TABLE>标记来绑定数据,但并不是所有的HTML元素都支持数据绑定。表10-5详细列举了这些元素,表中列是:

· HTML元素定义支持数据绑定的元素。

· 绑定属性定义绑定到数据的HTML元素的属性。例如上面的DIV标记,绑定的数据就放在innerText属性中。如果使用A标记,并将其绑定到一个字段,那么数据将会放在href属性中。

· 可否更新数据指出元素中的绑定数据是否能被更新。

· 可否表格绑定指出该元素是否允许绑定子元素。稍后会讨论这个内容。· 可否作为HTML显示指出数据是否能格式化为HTML文档。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有