html5中id和name的区别

html-css017

html5中id和name的区别,第1张

HTML 中 id与name 区别

一个name可以同时对应多个控件,比如checkbox和radio

而id必须是全文档中唯一的

id的用途

1) id是HTML元素的Identity,主要是在客户端脚本里用。

2) label与form控件的关联,如

      <label for="MyInput">My Input</label>

      <input id="MyInput" type="text">

     for属性指定与label关联的元素的id,不可用name替代

3)脚本中获得对象:IE支持在脚本中直接以id(而不是name)引用该id标识的对象。

例如上面的input,要在脚本中获得输入的内容,可以直接以 MyInput.value来获得。如果用DOM的话,则用document.getElementById("MyInput").value;

如果要用name的话,通常先得到包含控件的form,例如document.forms[0],然后从form再引用name,注意这样得到的是经过计算后将发送给服务器的值

name的用途

1)主要是用于获取提交表单的某表单域信息, 作为可与服务器交互数据的HTML元素的服务器端的标示,比如input、select、textarea、框架元素(iframe、frame、 window的名字,用于在其他frame或window指定target )和button等,这些元素都与表单(框架元素作用于form的target)提交有关,浏览器会根据name来设定发送到服务器的request, 在表单的接收页面只接收有name的元素,  所以赋ID的元素通过表单是接收不到值的。 我们可以在服务器端根据其Name通过Request.Params取得元素提交的值。在form里面,如果不指定name,就不会发送到服务器端。

2)HTML元素Input type='radio'分组,我们知道radio button控件在同一个分组类,check操作是mutex的,同一时间只能选中一个radio,这个分组就是根据相同的name属性来实现的。

3)建立页面中的锚点,我们知道<a href="URL">link</a>是获得一个页面超级链接,如果不用href属性,而改用name,如:<a name="PageBottom"></a>,我们就获得了一个页面锚点,如<strong><a name="1" id="1"></a>Experience (XP)</strong>,详见 示例

4)作为对象的Identity,如Applet、Object、Embed等元素。比如在Applet对象实例中,我们将使用其name来引用该对象。

5)在IMG元素和MAP元素之间关联的时候,如果要定义IMG的热点区域,需要使用其属性usemap,使usemap="#name"(被关联的MAP元素的Name)。

6)某些特定元素的属性,如attribute,meta和param。例如为Object定义参数<PARAM NAME = "appletParameter" VALUE = "value">或Meta中<META NAME = "Author" CONTENT = "Dave Raggett">。

此次课程主讲内容是ID元素

id是一个元素的唯一标识,需确保每个元素的id的独一性。

id至少由一个字符组成,且不能包含空字符。

具有不为空id属性的元素,可以在css或DOM的getElementById()

方法中方便调用。

不排除一个元素有多个id的可能。

id属性值必须反映该元素的内容。

格式:

# id名称{

属性:值

}

注意点:

1.每个HTML标签都有一个属性叫做id,也就是说每个标签都可以设置id

2.在用一个界面中id的名称是不可以重复的

3.在编写id选择器时一定要加#

4.id的名称是有一定的规范的

4.1 id的名称只能有数字/字母/下划线a-z 0-0 _

4.2 名称不能以数字开头

4.3 id名称不能是HTML的标签名称,不能是a,H1 IMG INPUT ...

4.4 在企业开发中一般情况下如果仅仅是设置样式,我们不会使用id,因为在前端开发中id是留给js使用的

-->

<p id="identity1"></p>

<p id="identity2"></p>

<p id="identity3"></p>

<p id="identity4"></p>