C#中Property和attribute与property的区别

Property和Attribute的区别_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
Property和Attribute的区别
P​r​o​p​e​r​t​y​和​A​t​t​r​i​b​u​t​e​的​区​别
阅读已结束,如果下载本文需要使用
想免费下载本文?
你可能喜欢Property:属性,所有的HTML元素都由HTMLElement类型表示,HTMLElement类型直接继承自Element并添加了一些属性,添加的这些属性分别对应于每个HTML元素都有下面的这5个标准特性:
id,title,lang,dir,className。DOM节点是一个对象,因此,他可以和其他的JavaScript对象一样添加自定义的属性以及方法。property的值可以是任何的数据类型,对大小写敏感,自定义的property不会出现在html代码中,只存在js中。
Attribute:特性,区别于property,attribute只能是字符串,大小写不敏感,出现在innerHTML中,通过类数组attributes可以罗列所有的attribute。
2. 相同之处
标准的 DOM properties 与 attributes
是同步的。公认的(非自定义的)特性会被以属性的形式添加到DOM对象中。如,id,align,style等,这时候操作property或者使用操作特性的DOM方法如getAttribute()都可以操作属性。不过传递给getAttribute()的特性名与实际的特性名相同。因此对于class的特性值获取的时候要传入&class&。
3. 不同之处
1).对于有些标准的特性的操作,getAttribute与点号(.)获取的值存在差异性。如href,src,value,style,onclick等事件处理程序。
2).href:getAttribute获取的是href的实际值,而点号获取的是完整的url,存在浏览器差异。
document.body.children[0]
a.href = '/'
alert( 'attribute:' +
a.getAttribute('href') ) // '/'
alert( 'property:' + a.href )
'/', others: full URL
src的值的获取类似href,不过IE也会返回full URL;
value值同样存在一些
&one-way'(单向)同步的内置属性。
例如,input.value 从 attribute 中同步(即 property 从 attribute
中获得同步)
&input type=&text&
value=&markup&&
var input =
document.body.children[0];
input.setAttribute('value',
alert( input.value ); // 'new', input.value changed
alert( input.getAtrribute(value) ); // 'new'
但是 attribute 不能从 property 中获得同步:
&input type=&text&
value=&markup&&
var input =
document.body.children[0];
input.value = 'new';
alert(input.getAttribute('value'));
// 'markup', not changed!
getAttribute获取的是初始值,而点号获取的是初始值或者.value修改后的值,例如当访问者输入了某些字符后,'value' attribute
在 property 更新后维持了原始值。原始值可以用来检验 input 是否变化,或者重置它。
对于style和onclick等事件处理程序,getAttribute方法访问时会返回字符串,而点号返回的是相应的对象和事件处理函数。
对于input中的checked属性
document.body.children[0]
alert( input.checked ) // true
input.getAttribute('checked') ) // empty string
getAttribute获取的是你是实际设置的值。而点号返回的是布尔值。
浏览器兼容性上的差别
1.在IE&9的浏览器中,可以用点号和getAttribute在相互之间访问自定义属性。
2.IE&8(包括IE8种的IE7兼容模式),property和attribute相同。因为attribute对大小写不敏感,在这种情况下,用getAttribute访问特性的时候,浏览器会选择第一次出现的值。
document.body.abba = 1 // assign property
(now can read it by getAttribute)
document.body.ABBA = 5 // assign property
with another case
// must get a property named 'ABba' in case-insensitive
alert( document.body.getAttribute('ABba') ) // 1
优先选择property
在实际应用中,98%的 DOM 操作都是使用 properties。
只有两种情形需要使用attributes
1.自定义 HTML attributes,因为它并不同步到DOM property。
2.访问内置的 HTML attributes,这些
attribute 不能从 property 同步过来。例如 INPUT标签的value值。
编程开发子分类JS中的attribute和property的区别和联系 - CSDN博客
查了好久,终于查到一个靠谱的了!
attribute和property到底是什么呢,有什么区别呢?这个或许很多人都没留意,或许认为是同一个东西。
要明确attribute和property是不同的东西就要先知道它们分别是什么,这个很难说得清,举些例子就明白了。
这里我们先以ff为标准,后面再说ie的区别。以div为例,查查网页制作完全手册,会找到它有以下属性:
ALIGN&&&&&&align
CLASS&&&&&&className
ID&&&&&&&&&&&&id
TITLE&&&&&&&title&
...&&&&&&&&&&&&...
其中第一列就是attribute,第二列就是property。
attribute是dom元素在文档中作为html标签拥有的属性;
property就是dom元素在js中作为对象拥有的属性。
& & & & 对于html的标准属性来说,attribute和property是同步的,是会自动更新的,
& & & & 但是对于自定义的属性来说,他们是不同步的,
先给出例子:body&
&ul id=&ul&&
&li&aaaaaaaa&/li&
&li&bbbbbbbb&/li&
&li&cccccccc&/li&
&div id=&t& tt=&1&&test&/div&
var o = document.getElementById('t');
o[&tt&]=&2&;
document.writeln(o.getAttribute(&tt&));
document.writeln(o[&tt&]);
o.setAttribute(&tt&,&3&);
document.writeln(o.getAttribute(&tt&));
document.writeln(o[&tt&]);
&/script&测试结果:
这个是自定义的属性;可以看出来attribute和property是不一样的;
div id=&t2& title=&title&&test2&/div&
&script type=&text/javascript&&
var o2=document.getElementById(&t2&);
o2.setAttribute(&title&, &ninini&);
o2[&title&]=&nihao&;
document.writeln(o2.getAttribute(&title&));
document.writeln(o2[&title&]);
&/script&测试结果:
nihao nihao
将赋值语句倒过来一下,可以发现,浏览器以后面赋值的为准;
&script type=&text/javascript&&
var o2=document.getElementById(&t2&);
o2[&title&]=&nihao&;
o2.setAttribute(&title&, &ninini&);
document.writeln(o2.getAttribute(&title&));
document.writeln(o2[&title&]);
测试结果:
ninini ninini
PS:需要记住的是: & &attribute指的是html标签中的属性;
& & & & & & & & & & & & & & & & & & & property指的是js对象中的属性;

我要回帖

更多关于 c语言 attribute 的文章

 

随机推荐