HTML中不支持靜態(tài)Expando的元素的問題
更新時間:2007年03月08日 00:00:00 作者:
在使用腳本統(tǒng)一處理一批頁面的時候,我希望通過被處理頁面的TITLE元素取到文檔的標題和我自定義的一些屬性。這些附加的屬性是我在服務(wù)器端通過Attributes集合添加的,可是運行的結(jié)果和我的期望老是相去甚遠,怎么我在TITLE元素里寫入的自定義屬性老是空值呢?
客服端和服務(wù)器端代碼分別是:
ASPX:
<title id="title" runat="server">Query Info</title>
C#: protected HtmlGenericControl title;
private void Page_Load(object sender, System.EventArgs e)
{
// ...
title.InnerHtml = "查詢信息";
title.Attributes["icon"] = "QueryInfo.gif;
}
HTML:
<title id="title" icon="QueryInfo.gif">查詢信息</title>
JavaScript:
var iconPath = docucment.all.tags('TITLE')[0].icon;
if ( iconPath )
{
var img = document.createElement('IMG');
img.src = iconPath;
// ...
}
結(jié)果就是總出不來我希望的那個icon,跟蹤JavaScript代碼,發(fā)現(xiàn)iconPath總是undefined。在看看HTML代碼,里面明明有icon="QueryInfo.gif"這個屬性值對。于是從title對象中去查看outerHTML,outerHTML居然是:<title id="title">查詢信息</title>。根本沒有icon那個屬性,難怪JavaScript取到的iconPath總是undefined的說。
仔細查下去,發(fā)現(xiàn)原來是html元素在處理expando屬性上有區(qū)別。我們給html元素添加expando屬性有兩種方式,一是我們常用的動態(tài)方式;就是使用腳本來給html元素添加expando屬性。二是使用靜態(tài)方式;即在html代碼中以literal方式添加expando屬性。分別舉例如下:
動態(tài)添加expando屬性: <span id=mySpan>this is a span element.</span>
<script language=javascript>
mySpan.myAttri = 'attribute';
</script>
靜態(tài)添加expando屬性: <span id=mySpan myAttri=attribute>this is a span element.</span>
本來這兩種寫法基本是沒有什么區(qū)別的,可是元素title卻只支持動態(tài)添加expando屬性,而不支持靜態(tài)添加expando屬性,這也就是為什么我開始會出錯誤的原因。那么還有那些html elements和title一樣不支持靜態(tài)添加expando屬性呢?在108個html elements中,以下10個元素都不支持靜態(tài)添加expando屬性:
HTML, HEAD, TITLE, BODY, BASEFONT, FORM, HR, HR, TBODY, SCRIPT
不過動態(tài)添加expando屬性,是所有的html elements和dhtml objects都支持的。
客服端和服務(wù)器端代碼分別是:
ASPX:
<title id="title" runat="server">Query Info</title>
C#: protected HtmlGenericControl title;
private void Page_Load(object sender, System.EventArgs e)
{
// ...
title.InnerHtml = "查詢信息";
title.Attributes["icon"] = "QueryInfo.gif;
}
HTML:
<title id="title" icon="QueryInfo.gif">查詢信息</title>
JavaScript:
var iconPath = docucment.all.tags('TITLE')[0].icon;
if ( iconPath )
{
var img = document.createElement('IMG');
img.src = iconPath;
// ...
}
結(jié)果就是總出不來我希望的那個icon,跟蹤JavaScript代碼,發(fā)現(xiàn)iconPath總是undefined。在看看HTML代碼,里面明明有icon="QueryInfo.gif"這個屬性值對。于是從title對象中去查看outerHTML,outerHTML居然是:<title id="title">查詢信息</title>。根本沒有icon那個屬性,難怪JavaScript取到的iconPath總是undefined的說。
仔細查下去,發(fā)現(xiàn)原來是html元素在處理expando屬性上有區(qū)別。我們給html元素添加expando屬性有兩種方式,一是我們常用的動態(tài)方式;就是使用腳本來給html元素添加expando屬性。二是使用靜態(tài)方式;即在html代碼中以literal方式添加expando屬性。分別舉例如下:
動態(tài)添加expando屬性: <span id=mySpan>this is a span element.</span>
<script language=javascript>
mySpan.myAttri = 'attribute';
</script>
靜態(tài)添加expando屬性: <span id=mySpan myAttri=attribute>this is a span element.</span>
本來這兩種寫法基本是沒有什么區(qū)別的,可是元素title卻只支持動態(tài)添加expando屬性,而不支持靜態(tài)添加expando屬性,這也就是為什么我開始會出錯誤的原因。那么還有那些html elements和title一樣不支持靜態(tài)添加expando屬性呢?在108個html elements中,以下10個元素都不支持靜態(tài)添加expando屬性:
HTML, HEAD, TITLE, BODY, BASEFONT, FORM, HR, HR, TBODY, SCRIPT
不過動態(tài)添加expando屬性,是所有的html elements和dhtml objects都支持的。
相關(guān)文章
小程序開發(fā)調(diào)用微信支付以及微信回調(diào)地址配置
本文主要介紹了小程序開發(fā)調(diào)用微信支付以及微信回調(diào)地址配置,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-05-05JS+html5實現(xiàn)異步上傳圖片顯示上傳文件進度條功能示例
這篇文章主要介紹了JS+html5實現(xiàn)異步上傳圖片顯示上傳文件進度條功能,結(jié)合完整實例形式分析了JavaScript前端結(jié)合HTML5實現(xiàn)post文件上傳與進度條顯示相關(guān)操作技巧,需要的朋友可以參考下2019-11-11JS使用隊列對數(shù)組排列,基數(shù)排序算法示例
這篇文章主要介紹了JS使用隊列對數(shù)組排列,基數(shù)排序算法,涉及javascript隊列的定義、使用,基數(shù)排序?qū)崿F(xiàn)方法等相關(guān)操作技巧,需要的朋友可以參考下2019-03-03使用?TypeScript?開發(fā)?React?函數(shù)式組件
這篇文章主要介紹了使用?TypeScript開發(fā)React函數(shù)式組件,文章通過圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下2022-08-08JavaScript代碼實現(xiàn)txt文件的上傳預(yù)覽功能
本篇文章給大家介紹了JavaScript代碼實現(xiàn)txt文件的上傳預(yù)覽功能,文字代碼相結(jié)合的形式給大家介紹的非常詳細,需要的朋友參考下吧2018-03-03