正 文:
很多时候,由于程序设计需要,要求在asp的include包含文件里调用动态的文件。如<!--#include file="map1.asp"-->其中的1是个动态参数,需要request获取。但可惜的是,include语句里并不能含有变量,否则将提示找不到文件错误。本文将提供3种方法解决该问题。
首先,我们需要了解,包含文件的提示和警告信息:被包含的文件可以包含其他文件。只要“#include”命令不导致循环,.asp 文件也可以多次包含同一文件。例如,如果文件 First.asp 包含文件 Second.inc,则 Second.inc 不能反过来包含 First.asp。文件也不能包含其自身。ASP 检测这样的循环或嵌套错误,生成错误消息,并停止处理请求的 .asp 文件。
解决方法一:FSO调用方法
ASP语言是强大易用的语言,我们不要把自己的思维局限固定在一个角落里,“条条大道通罗马”,一个思路不通,换个思路吧。
本方法采用变通的方法实现同样的包含功能。即FSO调用。代码如下:
<%
Function getFileContents(strIncludeFile) '函数:读取包含文件内容
Dim objFSO,objText,strPage
Set objFSO = Server.CreateObject("Scripting.FileSystemObject") '调用FSO对象
Set objText = objFSO.OpenTextFile(Server.MapPath(strIncludeFile))
getFileContents = objText.ReadAll
objText.Close
Set objText = Nothing
Set objFSO = Nothing
End Function
dim p
p=request("p") '2种方式:request.form ,request.querystring
response.write getFileContents("map"&p&".asp")
%>
这样,利用fso函数读取包含文件的内容,然后用response.write把包含文件的内容输出,即实现和include命令同样的功能了,轻松实现自由输出诸如 map1.asp,map2.asp… 等文件内容了。
解决方法二:if...elseif...
此方法适用于要包含的文件数量不多的情况下,也是懒人+笨人的方法,呵呵。代码如下:
<%if a=1 then%>
<!--#include file="map1.asp"-->
<%elseif a=2 then%>
<!--#include file="map2.asp"-->
<%elseif a=3 then%>
<!--#include file="map3.asp"-->
<%end if%>
解决方法三:select case
方法和第二种差不多,稍微好点。代码如下:
<%select case p
case 1%>
<!--#include virtual='inc/****1.asp'-->
<%case 2%>
<!--#include virtual='inc/****2.asp'-->
<%case 3%>
<!--#include virtual='inc/****3.asp'-->
<%case 4%>
<!--#include virtual='inc/****4.asp'-->
<%end select%>
如果你有其他更好的方法,欢迎与我们交流。您可以把你您的想法留在博客评论里,我们期待与您的探讨。
补充:关于asp的include包含命令,需要注意以下方面。
ASP程序在执行脚本命令之前就已经包含文件。因此,不能使用脚本命令来建立被包含的文件名。举例来说,因为 ASP 试图在将文件名指派给变量 name 之前执行“#include”命令,所以下面的脚本无法打开文件 Header1.inc。
<!-- 该脚本将失败 -->
<% name= header1.inc %>
<!-- #include file="<%= name %>" -->
脚本命令和过程必须完全包含在脚本分隔符 <% 和 %> 内,即 HTML 标签 <SCRIPT> 和 </SCRIPT>,或 HTML 标签 <OBJECT> 和 </OBJECT> 内部。也就是说,不能在包含 .asp 文件中打开脚本分隔符,并在被包含的文件中关闭分隔符;脚本或脚本命令必须是一个完整的单元。例如,下面的脚本将不起作用:
<!-- 该脚本将失败 -->
<%
For i = 1 To n
主文件中的语句
<!-- #include file="header1.inc" -->
Next
%>
但下面的脚本会起作用:
<%
For i = 1 to n
主文件中的语句
%>
<!-- #include file="header1.inc" -->
<% Next %>
如果 ASP 脚本包含的文件中存在包含脚本不需要的大量函数和变量,则这些无用的结构反而会影响性能,并最终降低 Web 应用程序的伸缩性。因此,通常将包含文件分成多个小文件,并且只包含那些服务器端脚本必需的文件,而不是包含那些带有冗余信息的一个或多个大型包含文件。
如果是用if else那还算什么动态?case也一样,所以我想用fso的方法,可惜我最后失败了。文章来源:http://www.piaoyi.org/asp/asp-include-variables.html
最后我是用的js的方法的XMLHttpRequest send ,responseText到div的innerHtml中得到了解决方法:
<%@LANGUAGE="VBSCRIPT" CODEPAGE="65001"%> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <script> window.onload = function () { var req = false; var url ="text"+Math.floor(Math.random()*10+1)+".asp"; // Safari, Firefox, 及其他非微软浏览器 if (window.XMLHttpRequest) { try { req = new XMLHttpRequest(); } catch (e) { req = false; } } else if (window.ActiveXObject) { // For Internet Explorer on Windows try { req = new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try { req = new ActiveXObject("Microsoft.XMLHTTP"); } catch (e) { req = false; } } } var element = document.getElementById("includefooter"); if (!element) { alert("函数clientSideInclude无法找到id " + id + "。" +"你的网页中必须有一个含有这个id的div 或 span 标签。"); return; } if (req) { // 同步请求,等待收到全部内容 req.open('GET', url, false); req.send(null); element.innerHTML = req.responseText; } else { element.innerHTML ="对不起,你的浏览器不支持" +"XMLHTTPRequest 对象。这个网页的显示要求" +"Internet Explorer 5 以上版本, " +"或 Firefox 或 Safari 浏览器,也可能会有其他可兼容的浏览器存在。"; } } </script> </head> <body> <span id="includefooter"></span> </body> </html>
代码来源:http://blog.csdn.net/huangxy10/article/details/8486719
相关推荐
下面是一个简单的示例,展示如何创建一个将数据集转换为嵌套JSON的函数: ```vbscript Function DatasetToJson(rs) Dim json, item, order, product Set json = Server.CreateObject("ASPJSON.Object") Do ...
在Repeater的ItemDataBound事件中,你可以检查当前项是否有子菜单,如果有,则创建一个新的嵌套Repeater,并将其绑定到该菜单项的子菜单数据。 4. **自定义模板**:在ASP.NET的HTML标记中,为Repeater定义...
本文将详细介绍如何在ASP.NET中使用Repeater控件嵌套另一个Repeater控件,并结合示例代码进行解析。 #### Repeater控件简介 Repeater控件是一种非常灵活的服务器控件,它可以用来显示重复的数据项。与GridView、...
在ASP.NET Web Forms开发中,`Repeater`控件是一个非常灵活的数据绑定控件,用于动态生成HTML结构,尤其适用于自定义布局的需求。而`DataList`控件则提供了更丰富的布局选项,如行和列的重复,可以用于创建表格或...
在.NET框架中,Repeater控件是一个非常灵活的服务器端控件,用于动态生成HTML输出。它非常适合用来显示数据集合,比如从数据库中检索的数据。本教程将深入讲解如何实现Repeater控件的嵌套,以及如何分别进行刷新绑定...
在某些场景下,我们可能需要实现DataGrid的多层嵌套,这通常发生在数据结构具有层次性的情况下,比如产品分类,每个产品可能有多个子分类,子分类又可能有更细的分类。在给定的文件描述中,提到了一个产品分类的例子...
在ASP.NET Web Forms开发中,`Repeater`控件是一个非常强大的数据绑定工具,它允许开发者自定义模板来展示数据。本实例主要探讨了如何在实际应用中使用`Repeater`进行嵌套以及添加分页功能,这对于理解和掌握动态...
在ASP.NET中,GridView嵌套通常是通过在模板字段(TemplateField)中添加另一个GridView来实现的。首先,我们需要创建一个外层GridView,然后在某个特定行的TemplateField中动态生成并绑定内层GridView。这可以通过...
在ASP.NET web开发中,`Repeater`控件是一个非常灵活的数据绑定控件,它用于动态生成HTML结构,尤其适用于创建列表或表格形式的数据展示。本主题将深入探讨如何实现"两个Repeater嵌套"的设计,以及如何用这种设计来...
首先,我们需要在Default.aspx页面上添加一个主GridView。主GridView将绑定到顶层数据源,如数据库查询结果。在GridView的每一行中,我们将内嵌一个子GridView,它会显示与当前主GridView行关联的子级数据。 在`...
在页面上,我们可以创建一个Repeater来遍历所有类别: ```asp <asp:Repeater ID="CategoryRepeater" runat="server"> <!-- 这里定义类别相关的HTML结构 --> <h2><%# Eval("CategoryName") %> <asp:Repeater ...
本文将深入探讨"(ASP.NET)Repeater嵌套"这一主题,旨在帮助开发者理解如何在ASP.NET中使用Repeater控件进行多层次的数据展示。 首先,Repeater控件是基于模板的,这意味着我们可以自定义其输出的HTML结构。这为创建...
在.NET开发中,Repeater控件是一个非常灵活的控件,常用于动态生成HTML列表或表格,尤其在数据绑定方面表现出色。本文将深入探讨如何在C#环境下进行多层Repeater的嵌套使用。 首先,理解Repeater的基本概念。...
在ASP.NET中,`frameset`框架集是一种将一个浏览器窗口分割成多个独立区域的技术,每个区域都可以独立显示不同的网页内容。这种技术特别适用于创建复杂的网页布局,尤其是在早期Web开发中非常流行。`frameset`可以...
1. **控件树的概念**:每个ASP.NET Web表单都有一个控件树,它包含了页面上所有控件的层次结构。遍历就是沿着这个树结构逐个访问每个控件。 2. **遍历方法**: - **递归遍历**:通常使用递归函数来遍历控件树。...
以上代码通过嵌套的if语句实现了对多个静态HTML页面的生成,如果所有页面都成功生成,则输出成功信息;反之,输出失败信息。 ### 总结 通过使用ASP脚本,我们可以有效地将动态页面转换为静态HTML页面,从而提升...
然而,当需要在一个单元格内展示复杂的数据结构时,单一的GridView可能无法满足需求,这时就可以引入嵌套控件的概念,比如嵌套一个DataList控件。 DataList控件相比于GridView,提供了更多的布局灵活性,它允许...
2. 在ASP.NET页面上添加两个Repeater控件,一个作为父级,一个作为子级。 3. 在父级Repeater的ItemTemplate中,插入子级Repeater,并在子级Repeater的DataSourceID属性中设置数据源表达式,这样它就能从父级...
首先,必须理解,当我们在***中谈论表单嵌套问题时,实际上是指在同一个HTML页面中,一个`<form>`标签不能被另一个`<form>`标签所包含。这是因为在HTML标准中,`<form>`标签是不允许嵌套的。当浏览器解析嵌套的表单...