转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 站长学院 >> Web开发 >> 正文
ASP.NET拾萃——服务器端控件篇(一)         ★★★★

ASP.NET拾萃——服务器端控件篇(一)

作者:闵涛 文章来源:闵涛的学习笔记 点击数:649 更新时间:2009/4/23 10:50:39
技巧一:在客户端的JavaScript脚本中获取服务器端控件的值

以前,当我们需要在脚本里访问页面内一个对象的时候,一般都是通过对象的id或name。就像这样——
<!--Test.html-->
// ...
function getText()
{
  return document.form1.Text1.value; // Text1就是对象的id
}

// ...

<INPUT id="Text1" type="text" ...>

现在,ASP.NET让我们越来越习惯使用TextBox作为用户输入的途径。如果我们想在客户端脚本里访问一个TextBox,原先的做法就行不通了——
<!--Test.aspx-->
// ...
function getText()
{
  return document.form1.Text1.value; // Text1还是对象的id?
}

// ...

<asp:TextBox id="Text1" .../>

浏览页面时,会有一个脚本错误——“Text1对象不存在”。原因就在于,Text1作为服务器端控件TextBox,在被发送到客户端之前,先由.NET Framework进行转换,而它的id显然也是转换的一部分。如果你在客户端查看页面的源代码,你可以发现原先的Text1已经不存在,取而代之的是一个普通的INPUT——
<input name="Test:Text1" type="text" id="Test_Text1" />

这就是转换的结果,id不再是设计时所指定的id。如果我们要在客户端访问这个文本输入框,也必须改变访问的id。如何改变?直接将
document.form1.Text1
改为
document.form1.item("Test_Text1") // 保险起见,使用item由id或name得到控件
或者
document.getElementByID("Test_Text1")  // 保险起见,使用getElementByID由id或name得到控件

可以吗?当然可以!只要你的控件id固定是"Text1"。
但是,只有这个条件还不够。"Test"又是什么?它也应该被考虑在内(幸好form的id不会改变,否则要关心的内容又会多一个)。
你或许已经看出,Test就是这个Web页面的名字。对吗?——不完全对:P
确切地说,控件转换后id中的"Test"是其所在的Web窗体对象的ClientID。所有的ASP.NET对象都在服务器端有一个实例(如果你面向对象的基础不够,建议也补完一次吧),而这个"Test",就是这个页面实例对象的ClientID。而ClientID,则是每个Web窗体页的一个属性,它指明了这个Web窗体在客户端的标识。
为什么要这么复杂?道理很简单,我们并不能在客户端脚本里确定页面的ClientID和控件的ID。
那应该怎样做呢?
“在服务器端代码里生成客户端JavaScript。”——似乎非常复杂,其实并不困难,只要在服务器端Page_Load事件里加上(在IsPostBack判断之外)——
RegisterStartupScript("start",
   "\n<script>\n" +
   "function getText()\n" +
   "{\n" +
   "   return document.forms(0).item(''''" + this.ClientID + ":" + this.Text1.ID + "'''');\n" +
   "}\n" +
   "</script>\n");

RegisterStartupScript是Web窗体(System.Web.UI.Page类)的一个方法,作用是在生成的页面里注册客户端脚本。
在这里,我们添加了一个getText()函数,作用和之前的getText()一样,所不同的在于,它所访问的控件id并非脚本内指定,而是在服务器端根据页面的ClientID(this.ClientID,this就是页面自己)和Text1控件的ID(this.Text1.ID)动态生成的。
编译之后重新浏览,我们会在新的页面源代码里找到这个由服务器端代码生成的JavaScript函数。此时,在页面的其他地方调用getText()函数就将正确得到Text1中的内容了。


[C语言系列]NET 中C#的switch语句的语法  [系统软件]托拽Explore中的文件到VB.net的窗口
[系统软件]Boost库在XP+Visual C++.net中的安装  [常用软件]新配色面板:Paint.Net3.0RC1官方下载
[常用软件]用内建的“Net Meeting”聊天  [VB.NET程序]Henry的VB.NET之旅(三)—共享成员
[VB.NET程序]Henry的VB.NET之旅(二)—构造与析构  [VB.NET程序]Henry的VB.NET之旅(一)—失踪的窗体
[VB.NET程序]在托盘上显示Balloon Tooltip(VB.NET)  [VB.NET程序]Henry手记-VB.NET中动态加载Treeview节点(二)
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Web开发  · 网页制作
    · 平面设计  · 网站运营
    · 网站推广  · 搜索优化
    · 建站心得  · 站长故事
    · 互联动态
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台