当前位置: 移动技术网 > IT编程>开发语言>.net > ASP 3.0高级编程(四十五)

ASP 3.0高级编程(四十五)

2019年01月23日  | 移动技术网IT编程  | 我要评论

茶杯猫多少钱一只,金诗麦闪电瘦,郭作贵

异步执行是指在后台检索数据,可以在全部数据返回之前在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

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网