欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ASP 3.0高级编程(四十五)

程序员文章站 2022-05-17 14:51:41
异步执行是指在后台检索数据,可以在全部数据返回之前在web页面上使用已经得到的数据。虽然可能需要的是全部的数据,但异步工作至少可提前开始处理数据。也可让用户先看到某些内容,这使得w...
异步执行是指在后台检索数据,可以在全部数据返回之前在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.">
</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";
       authors.refresh();
}
</script>
这将强迫数据控件使用新的属性值,并重新从数据提供者那里检索数据。除了refresh方法外,rds数据控件还有许多其他方法,如表10-3所示:
表10-3  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>
   &n