getElementById Vs getElementsByName Javascript 細說HTML元素的ID和N
也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!
getElementById Vs getElementsByName(Javascript)細說HTML元素的ID和Name屬性的區別ID(getElementById) Vs Name(getElementsByName) 幾乎每個做過Web開發的人都問過,到底元素的ID和Name有什麼區別阿?為什麼有了ID還要有Name呢?而同樣我們也可以得到最classical的答案:ID就像是一個人的身份證號碼,而Name就像是他的名字,ID顯然是唯一的,而Name是可以重複的。 上週我也遇到了ID和Name的問題,在頁面裡輸入了一個input type="hidden",只寫了一個ID='SliceInfo',賦值後submit,在後臺用Request.Params["SliceInfo"]卻怎麼也去不到值。後來恍然大悟因該用Name來標示,於是在input里加了個Name='SliceInfo',就一切ok了。 第一段裡對於ID和Name的解答說的太籠統了,當然那個解釋對於ID來說是完全對的,它就是Client端HTML元素的Identity。而Name其實要複雜的多,因為Name有很多種的用途,所以它並不能完全由ID來代替,從而將其取消掉。 具體用途有: 用途1: 作為可與伺服器互動資料的HTML元素的伺服器端的標示,比如input、select、textarea、和button等。我們可以在伺服器端根據其Name通過Request.Params取得元素提交的值。 用途2: HTML元素Input type='radio'分組, 我們知道radio button控制元件在同一個分組類,check操作是mutex的,同一時間只能選中一個radio,這個分組就是根據相同的Name屬性來實現的。 用途3: 建立頁面中的錨點,我們知道<a href="URL">link</a>是獲得一個頁面超級連結,如果不用href屬性,而改用Name,如:<a name="PageBottom"></a>,我們就獲得了一個頁面錨點。 用途4: 作為物件的Identity,如Applet、Object、Embed等元素。比如在Applet物件例項中,我們將使用其Name來引用該物件。 用途5: 在IMG元素和MAP元素之間關聯的時候,如果要定義IMG的熱點區域,需要使用其屬性usemap,使usemap="#name"(被關聯的MAP元素的Name)。 用途6: 某些特定元素的屬性,如attribute,和param。例如為Object定義引數<PARAM NAME = "appletParameter" VALUE = "value">。 顯然這些用途都不是能簡單的使用ID來代替掉的,所以HTML元素的ID和Name的卻別並不是身份證號碼和姓名這樣的區別,它們更本就是不同作用的東西。 當然HTML元素的Name屬性在頁面中也可以起那麼一點ID的作用,因為在DHTML物件樹中,我們可以使用document.getElementsByName來獲取一個包含頁面中所有指定Name元素的物件陣列。 在這裡順便說一下,要是頁面中有n(n>1)個HTML元素的ID都相同了怎麼辦?在DHTML物件中怎麼引用他們呢?如果我們使用ASPX頁面,這樣的情況是不容易發生的,因為aspnet程序在處理aspx頁面時根本就不允許有ID非唯一,這是頁面會被丟擲異常而不能被正常的render。要是不是動態頁面,我們硬要讓ID重複那IE怎麼搞呢? 這個時候我們還是可以繼續使用document.getElementById獲取物件,只不過我們只能獲取ID重複的那些物件中在HTML Render時第一個出現的物件。而這時重複的ID會在引用時自動變成一個數組,ID重複的元素按Render的順序依次存在於陣列中。getElementById 與 getElementsByName最近為了讓網頁在 IE 與 Firefox都可以正常執行,所以改了許多javascript,其中,Firefox最常出現的就是getElementById的問題,在IE中,之前是習慣在驗證表單的時候直接使用form的名稱去取得下面的表單元件,例如 : if (frm.tbxuid.value = ""){alert("請輸入帳號");} 但是,這樣的語法在firefox是不能跑的,所以需要改用getElementById去取得物件,可是,要使用getElementById的前提是表單的物件都需要有id的屬性內容,偏偏,之前沒有加ID的習慣…後來硬是將許多物件都加上了ID後發現…radio跟checkbox有問題…因為radio跟checkbox的name都是一樣的,但是id不能設定都是一樣的,(參考網址 : 細說HTML元素的ID和Name屬性的區別)所以,radio跟checkbox要用getElementsByName來抓,在使用getElementById時我是想說應該有ByName的但是測試了getElementByName,發覺沒有用…後來看了上面那篇文章才發現原來是少了個s (getElementByName 應該為 getElementsByName),後來還試了一下看看用getElementsByName抓不抓的到text或是areatext等資料,結果發現是抓不到的,所以還是硬著頭皮將表元件一個一個檢查了…所以像上面的程式就要改成if (document.getElementById('tbxuid').value = ""){alert("請輸入帳號");} 要讓所有的瀏覽器都可瀏覽還真是不容易啊…除非網頁的內容很單純….
新的改變
我們對Markdown編輯器進行了一些功能拓展與語法支援,除了標準的Markdown編輯器功能,我們增加了如下幾點新功能,幫助你用它寫部落格:
- 全新的介面設計 ,將會帶來全新的寫作體驗;
- 在創作中心設定你喜愛的程式碼高亮樣式,Markdown 將程式碼片顯示選擇的高亮樣式 進行展示;
- 增加了 圖片拖拽 功能,你可以將本地的圖片直接拖拽到編輯區域直接展示;
- 全新的 KaTeX數學公式
- 增加了支援甘特圖的mermaid語法1 功能;
- 增加了 多螢幕編輯 Markdown文章功能;
- 增加了 焦點寫作模式、預覽模式、簡潔寫作模式、左右區域同步滾輪設定 等功能,功能按鈕位於編輯區域與預覽區域中間;
- 增加了 檢查列表 功能。
功能快捷鍵
撤銷:Ctrl/Command + Z 重做:Ctrl/Command + Y 加粗:Ctrl/Command + B 斜體:Ctrl/Command + I 標題:Ctrl/Command + Shift + H 無序列表:Ctrl/Command + Shift + U 有序列表:Ctrl/Command + Shift + O 檢查列表:Ctrl/Command
合理的建立標題,有助於目錄的生成
直接輸入1次#,並按下space後,將生成1級標題。
輸入2次#,並按下space後,將生成2級標題。
以此類推,我們支援6級標題。有助於使用TOC
語法後生成一個完美的目錄。
如何改變文字的樣式
強調文字 強調文字
加粗文字 加粗文字
標記文字
刪除文字
引用文字
H2O is是液體。
210 運算結果是 1024.
插入連結與圖片
連結: link.
圖片:
帶尺寸的圖片:
當然,我們為了讓使用者更加便捷,我們增加了圖片拖拽功能。
如何插入一段漂亮的程式碼片
去部落格設定頁面,選擇一款你喜歡的程式碼片高亮樣式,下面展示同樣高亮的 程式碼片
.
// An highlighted block var foo = 'bar';
生成一個適合你的列表
- 專案
- 專案
- 專案
- 專案
- 專案1
- 專案2
- 專案3
- 計劃任務
- 完成任務
建立一個表格
一個簡單的表格是這麼建立的:
專案 | Value |
---|---|
電腦 | $1600 |
手機 | $12 |
導管 | $1 |
設定內容居中、居左、居右
使用:---------:
居中
使用:----------
居左
使用----------:
居右
第一列 | 第二列 | 第三列 |
---|---|---|
第一列文字居中 | 第二列文字居右 | 第三列文字居左 |
SmartyPants
SmartyPants將ASCII標點字元轉換為“智慧”印刷標點HTML實體。例如:
TYPE | ASCII | HTML |
---|---|---|
Single backticks | 'Isn't this fun?' |
‘Isn’t this fun?’ |
Quotes | "Isn't this fun?" |
“Isn’t this fun?” |
Dashes | -- is en-dash, --- is em-dash |
– is en-dash, — is em-dash |
建立一個自定義列表
- Markdown
- Text-to-HTML conversion tool
- Authors
- John
- Luke
如何建立一個註腳
一個具有註腳的文字。2
註釋也是必不可少的
Markdown將文字轉換為 HTML。
KaTeX數學公式
您可以使用渲染LaTeX數學表示式 KaTeX:
Gamma公式展示 是通過尤拉積分
你可以找到更多關於的資訊 LaTeX 數學表示式here.
新的甘特圖功能,豐富你的文章
gantt
dateFormat YYYY-MM-DD
title Adding GANTT diagram functionality to mermaid
section 現有任務
已完成 :done, des1, 2014-01-06,2014-01-08
進行中 :active, des2, 2014-01-09, 3d
計劃一 : des3, after des2, 5d
計劃二 : des4, after des3, 5d
- 關於 甘特圖 語法,參考 這兒,
UML 圖表
可以使用UML圖表進行渲染。 Mermaid. 例如下面產生的一個序列圖::
這將產生一個流程圖。:
- 關於 Mermaid 語法,參考 這兒,
FLowchart流程圖
我們依舊會支援flowchart的流程圖:
- 關於 Flowchart流程圖 語法,參考 這兒.
匯出與匯入
匯出
如果你想嘗試使用此編輯器, 你可以在此篇文章任意編輯。當你完成了一篇文章的寫作, 在上方工具欄找到 文章匯出 ,生成一個.md檔案或者.html檔案進行本地儲存。
匯入
如果你想載入一篇你寫過的.md檔案或者.html檔案,在上方工具欄可以選擇匯入功能進行對應副檔名的檔案匯入, 繼續你的創作。