ASP.NET拾萃——服务器端控件篇(一)〖本文对服务器控件有错误认识〗

原创 2003年06月13日 15:57:00
技巧一:在客户端的JavaScript脚本中获取服务器端控件的值

以前,当我们需要在脚本里访问页面内一个对象的时候,一般都是通过对象的id或name。就像这样——

// ...
function getText()
{
  return document.form1.Text1.value; // Text1就是对象的id
}

// ...



现在,ASP.NET让我们越来越习惯使用TextBox作为用户输入的途径。如果我们想在客户端脚本里访问一个TextBox,原先的做法就行不通了——

// ...
function getText()
{
  return document.form1.Text1.value; // Text1还是对象的id?
}

// ...

<?xml:namespace prefix = asp />?id="Text1"?...>

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

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

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

  • zgqtxwd
  • zgqtxwd
  • 2008年04月24日 15:19
  • 103

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

  • zgqtxwd
  • zgqtxwd
  • 2008年04月24日 15:19
  • 90

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

  • zgqtxwd
  • zgqtxwd
  • 2008年04月24日 11:54
  • 85

ASP.NET自定义服务器控件

最简单的服务器端控件开发流程简介。
  • yanwushu
  • yanwushu
  • 2014年04月08日 21:34
  • 4404

ASP.NET中服务器控件的生命周期

服务器控件的生命周期是创建服务器控件最重要的概念。作为开发人员,必须对服务器控件生命周期深刻理解。当然,这不是一朝一夕就可以做到的。对于学习控件开发技术的初学者,可以不必掌握得非常详细深入,只需对服务...
  • bigpudding24
  • bigpudding24
  • 2015年10月28日 21:25
  • 827

html控件、html服务器控件和web用户控件(onclick,onclientclick和onserverclick的执行顺序)

html控件、html服务器控件和web用户控件  asp.net之所以现在开发方便和快捷,关键是它有一组强大的控件库,包括web服务器控件,web用户控件,web自定义控件,html服务器控件和h...
  • junboyboy
  • junboyboy
  • 2014年04月06日 20:48
  • 1131

一篇非常好的服务器控件原理讲解文章

一篇非常好的服务器控件原理讲解文章(转载) 回发与事件基于WEB的分布式系统中,用户往往是通过提交表单,浏览器产生相应的HTTP POST请求来提出交互申请,这个过程称为回发(PostBack)。在同...
  • JavaK
  • JavaK
  • 2007年05月10日 12:10
  • 1193

asp.net中什么时候用服务器控件,什么时候该用html控件

Asp.net开发中,控件无疑给开发人员带来了方便,大大提高了开发速度,如果纯粹的用托控件方式来开发网站,我想应该没有其他什么开发工具能够拼的过visual studio(以下简称vs)了。一个企业站...
  • lvjin110
  • lvjin110
  • 2013年08月16日 16:33
  • 2553

asp.net服务器控件和客户端控件的几点区别小结

1、js获取控件方法的差异     获取服务器控件的写法:     var dunitcode=document.getElementById('').value;       获取客户端(静...
  • lmdcszh
  • lmdcszh
  • 2013年03月15日 14:09
  • 1626

ASP.NET服务器控件开发

利用ASP.NET 2.0技术,创建Web自定义服务器控件并不是一件轻松的事情。因为,这需要开发人员了解并能够灵活应用多种Web开发技术,例如,CSS样式表、客户端脚本语言、.NET开发语言、服务器控...
  • huang7914
  • huang7914
  • 2008年04月25日 22:38
  • 3308
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ASP.NET拾萃——服务器端控件篇(一)〖本文对服务器控件有错误认识〗
举报原因:
原因补充:

(最多只允许输入30个字)