html控件、html服务器控件等的区别详解


======================================================
注:本文源代码点此下载
======================================================

asp.net之所以现在开发方便和快捷,关键是它有一组强大的控件库,包括web服务器控件,web用户控件,web自定义控件,html服务器控件和html控件等。这里我主要说说html控件

、html服务器控件和web服务器控件的区别。

1、html控件:就是我们通常的说的html语言标记,这些语言标记在已往的静态页面和其他网页里存在,不能在服务器端控制的,只能在客户端通过javascript和vbscript等程序

语言来控制。

如:

2、html服务器控件:其实就是html控件的基础上加上runat="server"所构成的控件.它们的注意区别是运行方式不同,html控件运行在客户端,而html服务器控件是运行在服务

器端的。参考其他资料是这样说的: 当asp.net 网页执行时,会检查标注有无runat 属性,如果标注没有设定,那么html标注就会被视为符串,并被送到字符串流等待送到客户端

,客户端的浏览器会对其进行解释;如果html标注有设定runat="server" 属性,page 对象会将该控件放入控制器,服务器端的代码就能对其进行控制,等到控制执行完毕后再将

html服务器控件的执行结果转换成html标注,然后当成字符串流发送到客户端进行解释。

如:

3、web服务器控件:也称asp.net服务器控件,是web form编程的基本元素,也是asp.net所特有的。它会按照client的情况产生一个或者多个html控件,而不是直接描述html元

素。

如:

那么它和html服务器控件有什么区别呢?参照其他网页的资料看法如下:

1)、asp.net服务器控件提供更加统一的编程接口,如每个asp.net服务器控件都有text属性。

2)、隐藏客户端的不同,这样程序员可以把更多的精力放在业务上,而不用去考虑客户端的浏览器是ie还是firefox,或者是移动设备。

3)、asp.net服务器控件可以保存状态到viewstate里,这样页面在从客户端回传到服务器端或者从服务器端下载到客户端的过程中都可以保存。

4)、事件处理模型不同,html标注和html服务器控件的事件处理都是在客户端的页面上,而asp.net服务器控件则是在服务器上,举例来说:

是html服务器控件,此时我们点击此按钮,页面不会回传到服务器端,原因是我们没有为其定义鼠标

点击事件。

我们为html服务器控件添加了一个onserverclick事件,点击此按钮页面会

发回服务器端,并执行test(object sender, eventargs e)方法。

是asp.net服务器控件,并且我们没有为其定义click,但是我们点击时,页面也会发回到服务器端。

由此可见:html标注和html服务器控件的事件是由页面来触发的,而asp.net服务器控件则是由页面把form发回到服务器端,由服务器来处理。

4、下面我就结合我自己的测试来说明问题:

这段代码是我放在repeat中的模板里的:其中deletecheck是一个js脚本函数,注意是用于是否发送到服务器端的,这里就不展示脚本代码了。

button-button

展现出来的html代码如下:

button-button

可以看出以下几点:

1、当控件属性中有runat="server"时,生成的html控件时name和id发生的变化(.net framework)。

2、当asp:button服务器按钮通过生成的页面后转化成类型为submit类型的client控件。

3、当控件是html控件时通过生成的页面和原来的html代码完全一样(理由上面已经说名)。

另外我还测试了把这段代码直接放到form标记中(不放到其他子标记中)如:

button-button

linkbutton

直接放到form 标记中生成的html代码

button-button

linkbutton

这里有可以看出几点:

1、当html服务器控件在服务器端添加了服务器事件后生成的代码变为:οnclick="_dopostback()",实际上是调用脚本把整个窗体提交到服务器(如果没有添件服务器事件而只

是添加了runat="server"是不会发送到服务器端的)。这里注意如果要在html服务器控件中添加一个客户端事件如上面的

变成

那样生成的html代码变成

提示有脚本错误原因是onclick事件执行了2个脚本且书写的格式不正确。οnclick="return deletecheck(this);_dopostback()"这样的话就只能执行第一个函数而第二个函数就不

能执行了(return).如果用 οnclick="return deletecheck(this),_dopostback()"是指2个函数同时都要执行没有影响(相当于一条语句)。

2、asp:button中的onclientclick事件生成后就变成了onclick事件了,类型变成了type="submit".然而服务器事件的onclick我想是通过发送到服务器端执行的。

3、linkbutton不定义onclick事件,它会自动的生成下面代码发送到服务器端。 href="javascript:__dopostback('linkbutton1',' ')"

4、asp:button中的onclientclick事件生成后就变成了onclick事件了,类型变成了type="submit".然而服务器事件的onclick我想是通过发送到服务器端执行的。


======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值