在JavaScript中對文字編輯也是經常,通常標簽不復雜性況下,我們也可以直接對標簽內的容進行讀取和修改操作,介于兼容性不是很理想前提下,我們先來了解下相關的方法及其他瀏覽器中替代的方法,結合實例讓大家快掌握及投入到實際工作中。
? ? ? ?1.innerText屬性
通過innertText屬性可以操作元素中包含的所有文本內容,無論文本位于子文檔樹中的什么位置。在通過innerText讀取值時,它會按照由淺入深的順序,將子文檔樹中的所有文本拼接起來。以下面的HTML代碼為例:
? ? ? ?
This is aparagraph with a list following it.
? ? ? ?
- ltem l
- ltem 2
- ltem 3
? ? ? ?
? ? ? ?
? ? ? ?
? ? ? ?
? ? ? ?對于這個例子中的
元素而言,其innerText屬性會返回下列字符串:
? ? ? ?This is a paragraph with a list following it.
? ? ? ?Item l
? ? ? ?Item 2
? ? ? ?Item 3
? ? ? ?由于不同瀏覽器處理空白符的方式不同,因此輸出的文本可能會也可能不會包含原始HTML代碼中的縮進。
使用innerText屬性設置這個
? ? ? ?設置innerText永遠只會生成當前節點的一個子文本節點,而為了確保只生成一個子文本節點, 就必須要對文本進行HTML編碼。此外,還可利用innerText屬性過濾掉HTML標簽。方法是將 innerText設置為等于innerText,這樣就可以去掉所有HTML標簽,如下所示:
? ? ? ?div.innerText=div.innerText:
? ? ? ?執行這行代碼的結果就是用原來的文本替換容器元素中的所有內容。 ? ? ? ?在此,南昌網站制作公司百恒網絡開發工程師提示大家IE、Safari、Opera和Chrome支持innerText屬性。Firefox雖然不支持innerText,但支持作用類似的textContent屬性。textContent是DOM3級規定的一個屬性,而且也得到了Safari、Opera 和Chrome的支持。為了確保跨瀏覽器兼容,有必要像下面這樣通過函數來檢測可以使用哪個屬性:
function getInnerText(element){
? ? ? ?return ( typeof element.textContent=="string") ?
? ? ? ? ? ? ? element.textContent : element.innerText:
? ? ? ?}
function setInnerText(element, text){
? ? ? ?if (typeof element.textContent== "string"){
? ? ? ? ? ? ? element.textContent=text:
? ? ? ?} else {
? ? ? ? ? ? ? element.innerText=text:
? ? ? ?}
}
? ? ? ?這兩個函數都接受一個元素,然后檢查這個元素是不是有textContent屬性。如果有,那么type of element.textContent應該是"string";如果沒有,那么這兩個函數就會改為使用innerText,可以像下面這樣調用這兩個函數:
? ? ? ?setInnerText( div, "Hello worldl“);
? ? ? ?alert( getinnerText (div)); //"Hello world!"
使用這兩個函數可以確保在不同的瀏覽器中使用正確的屬性。
2.innerHTML屬性
? ? ? ?innerHTML與innerText在很多方面都很相似。在讀取信息時,innerHTML返回當前元素所有子節點的HTML表現,包括元素、注釋及文本節點。在寫入信息時,innerHTML會按照指定的值創建新的DOM子樹,并以該子樹替換當前元素的所有子節點。提到innerHTML與innerText之間最 主要的區別,無非就是innerHTML處理的是HTML字符串,而innerText處理的是普通文本字符串。
以下面的HTML代碼為例:
? ? ? ?
< /div>
這里面
? ? ? ?This is a paragraph with a list following it.
? ? ? ?Item l
? ? ? ?Item 2
? ? ? ?Item 3
? ? ? ?由于不同瀏覽器處理空白符的方式不同,因此輸出的文本可能會也可能不會包含原始HTML代碼中的縮進。
使用innerText屬性設置這個
元素的內容,則只需一行代碼:
? ? ? ?div.innerText="Hello world!;
? ? ? ?執行這行代碼后,頁面的HTML代碼就會變成如下所示:
? ? ? ?
? ? ? ?可見,設置innerText屬性移除了先前存在的所有子節點,完全改變了DOM子樹。此外,通過設置innerText屬性還可以對所有出現在文本中的HTML語法字符(小于號、大干號、引號及和號)進行編碼。例如,下面的這行代碼:
? ? ? ?div.innerText="Hello&welcome, "reader"!";
? ? ? ?運行之后的結果如下:
? ? ? ?< div id=‘’content">Hello & welcome,<b>" reader"!< /b>
? ? ? ?div.innerText="Hello world!;
? ? ? ?執行這行代碼后,頁面的HTML代碼就會變成如下所示:
? ? ? ?
Hello world!
? ? ? ?可見,設置innerText屬性移除了先前存在的所有子節點,完全改變了DOM子樹。此外,通過設置innerText屬性還可以對所有出現在文本中的HTML語法字符(小于號、大干號、引號及和號)進行編碼。例如,下面的這行代碼:
? ? ? ?div.innerText="Hello&welcome, "reader"!";
? ? ? ?運行之后的結果如下:
? ? ? ?< div id=‘’content">Hello & welcome,<b>" reader"!< /b>
? ? ? ?設置innerText永遠只會生成當前節點的一個子文本節點,而為了確保只生成一個子文本節點, 就必須要對文本進行HTML編碼。此外,還可利用innerText屬性過濾掉HTML標簽。方法是將 innerText設置為等于innerText,這樣就可以去掉所有HTML標簽,如下所示:
? ? ? ?div.innerText=div.innerText:
? ? ? ?執行這行代碼的結果就是用原來的文本替換容器元素中的所有內容。 ? ? ? ?在此,南昌網站制作公司百恒網絡開發工程師提示大家IE、Safari、Opera和Chrome支持innerText屬性。Firefox雖然不支持innerText,但支持作用類似的textContent屬性。textContent是DOM3級規定的一個屬性,而且也得到了Safari、Opera 和Chrome的支持。為了確保跨瀏覽器兼容,有必要像下面這樣通過函數來檢測可以使用哪個屬性:
function getInnerText(element){
? ? ? ?return ( typeof element.textContent=="string") ?
? ? ? ? ? ? ? element.textContent : element.innerText:
? ? ? ?}
function setInnerText(element, text){
? ? ? ?if (typeof element.textContent== "string"){
? ? ? ? ? ? ? element.textContent=text:
? ? ? ?} else {
? ? ? ? ? ? ? element.innerText=text:
? ? ? ?}
}
? ? ? ?這兩個函數都接受一個元素,然后檢查這個元素是不是有textContent屬性。如果有,那么type of element.textContent應該是"string";如果沒有,那么這兩個函數就會改為使用innerText,可以像下面這樣調用這兩個函數:
? ? ? ?setInnerText( div, "Hello worldl“);
? ? ? ?alert( getinnerText (div)); //"Hello world!"
使用這兩個函數可以確保在不同的瀏覽器中使用正確的屬性。
2.innerHTML屬性
? ? ? ?innerHTML與innerText在很多方面都很相似。在讀取信息時,innerHTML返回當前元素所有子節點的HTML表現,包括元素、注釋及文本節點。在寫入信息時,innerHTML會按照指定的值創建新的DOM子樹,并以該子樹替換當前元素的所有子節點。提到innerHTML與innerText之間最 主要的區別,無非就是innerHTML處理的是HTML字符串,而innerText處理的是普通文本字符串。
以下面的HTML代碼為例:
This is aparagraph with a list following it.
? ? ? ?
- ltem l
- ltem 2
- ltem 3
? ? ? ? ? ? ?
? ? ? ? ? ? ?
? ? ? ? ? ? ?
? ? ? ?
< /div>
這里面
元素的innerHTML屬性將返回下列字符串:
? ? ? ?在不同瀏覽器中,innerHTML返回的文本可能會有所不同。IE和Opera常常把所有標簽轉換為大寫,而Safari、Chrome和Firefox則以文檔中指定的形式返回HTML-包括空格和縮進。不要指望所有瀏覽器都會返回沒有絲毫差別的innerHTML值。
? ? ? ?在寫入信息時,innerHTML會將給定的字符串解析為DOM子樹,并用這個子樹替換所有的子節 點。由于賦給innerHTML的字符串會被當作HTML,因此其中包含的所有標簽都會按照瀏覽器處理 HTML的標準方式,被轉換成對應的元素(同樣,這個過程也會因瀏覽器而異)。如果像下面這樣, 只設置簡單的文本,那么結果就如同設置innerText -樣:
? ? ? ?div.innerHTML="Hello world!":
? ? ? ?如果為innerHTML設置的字符串中包含HTML代碼,結果可能就會大不一樣了。區別就在于innerText會轉義HTML語法字符,而innerHTML會解析它們。來看下面的例子:
? ? ? ?div.innerHTML="Hello&welcome, \"reader"!";
? ? ? ?執行這行代碼之后的結果是:
? ? ? ?
? ? ? ?在設置完innerHTML之后,馬上就可以像訪問文檔中的其他節點一樣訪問新生成的節點。
? ? ? ?設置innerHTML會導致瀏覽器將HTML字符串解析為對應的DOM樹。換句話說,設置完innerHTML之后再讀取它,將會得到一個差別很大的字符串。這個字符串不再是原始的
HTML代碼,而是根據原始HTML字符串創建的DOM子樹經過序列化之后的結果。
? ? ? ?innerHTML也有一些限制。首先,在多數瀏覽器中,通過innerHTML插入的
蜜臂av日日欢夜夜爽一区_成人一区二区三区在线观看
_日韩国产欧美三级_成人福利视频网站_石原莉奈在线亚洲二区_国产一区二区三区四区五区美女_国产一区二区三区av电影
_91麻豆福利精品推荐_日韩精品1区2区3区_93久久精品日日躁夜夜躁欧美
首页亚洲欧美制服丝腿|
国产福利一区在线观看|
精品综合免费视频观看|
成人在线视频首页|
热久久久久久久|
福利电影一区二区|
美腿丝袜在线亚洲一区|
成人av免费在线播放|
久久成人久久鬼色|
日韩精品色哟哟|
粉嫩蜜臀av国产精品网站|
麻豆精品一区二区综合av|
av一区二区三区在线|
国内精品伊人久久久久影院对白|
99re在线精品|
成人自拍视频在线观看|
国产一区二区在线看|
日本va欧美va精品|
99久久国产综合精品色伊|
国产成人精品一区二区三区四区
|
国产成人午夜99999|
91美女片黄在线观看|
国产精品自在在线|
久久成人18免费观看|
日韩av午夜在线观看|
a亚洲天堂av|
国产成人精品一区二|
国内精品久久久久影院色|
日本欧美加勒比视频|
91蝌蚪porny|
91美女视频网站|
99综合电影在线视频|
成人激情视频网站|
成人免费黄色大片|
成人精品视频一区二区三区尤物|
国产成人丝袜美腿|
国产成人精品三级麻豆|
国产成人亚洲综合a∨猫咪|
国产一区在线精品|
国产精品一区免费在线观看|
国产精品中文字幕日韩精品|
国产麻豆一精品一av一免费
|
精品午夜久久福利影院|
毛片av一区二区|
免费观看日韩av|
久久精品国产秦先生|
久久成人免费网|
国内成+人亚洲+欧美+综合在线|
激情六月婷婷久久|
国产精品一区二区你懂的|
国产美女av一区二区三区|
国产精品一卡二|
不卡视频在线看|
天堂成人免费av电影一区|
日韩不卡一区二区|
久久精品免费看|
国产麻豆精品在线观看|
成人听书哪个软件好|
91在线你懂得|
久久福利视频一区二区|
国产成人自拍网|
91浏览器在线视频|
久久草av在线|
成人一区二区三区视频在线观看|
91亚洲国产成人精品一区二区三|
七七婷婷婷婷精品国产|
国产精品伊人色|
99久久精品国产观看|
麻豆一区二区99久久久久|
国产麻豆9l精品三级站|
www.99精品|
九九视频精品免费|
va亚洲va日韩不卡在线观看|
另类欧美日韩国产在线|
成人久久18免费网站麻豆|
日韩av网站免费在线|
国产精品18久久久久久vr|
91网站在线观看视频|
久久99精品视频|
成人丝袜18视频在线观看|
美女视频第一区二区三区免费观看网站|
精品一区二区三区的国产在线播放|
国产成a人无v码亚洲福利|
日韩精品成人一区二区在线|
国产精品一区二区三区乱码
|
国产一区二区调教|
不卡视频一二三|
久久超碰97人人做人人爱|
99久久99久久精品免费观看|
久久99日本精品|
日韩精品一级中文字幕精品视频免费观看
|
国产精品自拍av|
日韩黄色免费电影|
国产成人午夜电影网|
捆绑紧缚一区二区三区视频|
99久久精品免费看国产
|
高清国产一区二区三区|
久久综合综合久久综合|
99re免费视频精品全部|
国产成人av一区二区|
奇米亚洲午夜久久精品|
91一区二区在线|
成人午夜视频在线|
国产精品中文有码|
黑人巨大精品欧美黑白配亚洲|
日本系列欧美系列|
视频一区二区欧美|
91一区一区三区|
91在线高清观看|
99久久国产综合色|国产精品|
丁香五精品蜜臀久久久久99网站
|
蜜桃视频在线观看一区|
国产成人在线影院|
国产麻豆视频精品|
国产在线视频不卡二|
久久国产视频网|
蜜臀av国产精品久久久久
|
99久久精品国产网站|
东方欧美亚洲色图在线|
国产成人av电影在线观看|
国产精品白丝jk白祙喷水网站|
精品无人码麻豆乱码1区2区|
精品一区二区在线免费观看|
久久99精品久久久久婷婷|
久久se这里有精品|
国产在线视频不卡二|
国产老肥熟一区二区三区|
国产一区二区三区不卡在线观看|
激情综合色播激情啊|
国产一区二区在线看|
国产成人自拍网|
成人少妇影院yyyy|
91丨porny丨蝌蚪视频|
日韩在线播放一区二区|
蓝色福利精品导航|
国产美女精品在线|
www.欧美精品一二区|
天堂一区二区在线免费观看|
男男成人高潮片免费网站|
精品在线一区二区|
成人在线视频一区二区|
91丝袜国产在线播放|
青青草原综合久久大伊人精品优势|
蜜臂av日日欢夜夜爽一区|
国产一区视频在线看|
成人18视频在线播放|
日本不卡视频一二三区|
国产一区二区福利|
aaa欧美色吧激情视频|
日韩在线一区二区三区|
国产一区二区三区黄视频|
成人手机电影网|
日av在线不卡|
国产98色在线|日韩|
日韩中文字幕麻豆|
国产成人啪午夜精品网站男同|
caoporen国产精品视频|
久久精品国产999大香线蕉|
丁香网亚洲国际|
免费一级片91|
成人黄色在线视频|
九色综合狠狠综合久久|
成人av第一页|
国产精品自产自拍|
人人狠狠综合久久亚洲|
成人综合在线视频|
精品一区二区三区久久久|
av成人免费在线观看|
韩国欧美国产1区|
日韩中文字幕亚洲一区二区va在线|
国产综合一区二区|
日韩av电影一区|
eeuss鲁片一区二区三区在线观看|
麻豆专区一区二区三区四区五区|
大白屁股一区二区视频|
国产在线精品一区二区三区不卡
|
视频在线观看一区|
国产成人综合在线播放|
开心九九激情九九欧美日韩精美视频电影
|
欧美aaaaa成人免费观看视频|
国产成人综合网|
精品一区二区三区久久久|
日韩中文字幕一区二区三区|
成人小视频免费在线观看|
激情国产一区二区|
六月婷婷色综合|
日韩有码一区二区三区|
www.欧美色图|
不卡一区二区三区四区|
国产成人在线视频免费播放|
久久se精品一区精品二区|
日韩精品乱码免费|
91女神在线视频|
91影院在线观看|
99久久国产综合色|国产精品|
国产99一区视频免费|
国产制服丝袜一区|
久草这里只有精品视频|
久久福利视频一区二区|
麻豆精品视频在线|
老司机精品视频导航|
美女视频一区二区三区|
七七婷婷婷婷精品国产|
琪琪一区二区三区|
免费美女久久99|
久久精品72免费观看|
精品一区二区三区视频在线观看|
久久精品国产成人一区二区三区|
麻豆成人久久精品二区三区小说|
美女视频免费一区|
精品一区二区三区视频|
国产一区二区伦理片|
国产成人免费视频|
av在线不卡观看免费观看|
99精品国产热久久91蜜凸|
日韩精品亚洲专区|
麻豆一区二区三|
国产一区二区三区香蕉|
国产黑丝在线一区二区三区|
成人性生交大合|
99久久精品免费|
蜜臀国产一区二区三区在线播放|
麻豆国产精品777777在线|
国产自产2019最新不卡|
福利一区二区在线观看|
91在线精品秘密一区二区|
免费在线看成人av|
国产在线精品一区二区三区不卡
|
av电影天堂一区二区在线观看|
99精品一区二区三区|
蜜桃一区二区三区四区|
国产成人一区在线|
91在线云播放|
久久99精品久久久久久|
成人永久免费视频|
青青草精品视频|
国产白丝网站精品污在线入口|
av影院午夜一区|
韩日欧美一区二区三区|
成人激情免费网站|
麻豆视频观看网址久久|
成人精品免费网站|
麻豆成人免费电影|
k8久久久一区二区三区|
久久电影国产免费久久电影|
不卡的av中国片|
久久国产精品72免费观看|
成人aa视频在线观看|
久久国产欧美日韩精品|
99在线热播精品免费|
国产一区二区导航在线播放|
91天堂素人约啪|
国产福利不卡视频|
裸体一区二区三区|
91小视频在线观看|
福利视频网站一区二区三区|
看片的网站亚洲|
91小视频在线免费看|
国产精品12区|
久久66热偷产精品|
日韩成人av影视|
zzijzzij亚洲日本少妇熟睡|
国产麻豆精品在线|
久久精品国产99|
日韩国产欧美在线观看|
99这里都是精品|
国产91高潮流白浆在线麻豆|
狠狠色综合播放一区二区|
日韩av中文在线观看|
94色蜜桃网一区二区三区|
国产91在线观看|
国产精品一区二区不卡|
精品午夜久久福利影院|
日韩av在线发布|
天堂影院一区二区|
91麻豆免费看|
gogo大胆日本视频一区|
国产福利91精品|
国产成人在线视频播放|
国产在线精品一区在线观看麻豆|
裸体一区二区三区|
美女尤物国产一区|
免费人成在线不卡|
日产国产欧美视频一区精品|
首页欧美精品中文字幕|
91色婷婷久久久久合中文|
99v久久综合狠狠综合久久|
成人国产精品免费观看动漫|
懂色av中文字幕一区二区三区|
国产麻豆9l精品三级站|
国产剧情一区二区三区|
国产一区二区福利视频|
国产精品一区在线|
国产成人精品影视|
成人一区二区三区在线观看|
gogogo免费视频观看亚洲一|
jizz一区二区|
三级久久三级久久久|
日韩av一区二区在线影视|
免费观看30秒视频久久|
开心九九激情九九欧美日韩精美视频电影|
青青草一区二区三区|
麻豆精品在线播放|
国产精品自拍在线|
国产91精品久久久久久久网曝门|
大陆成人av片|
水野朝阳av一区二区三区|
日本不卡一区二区三区|
六月丁香综合在线视频|
国产精品综合视频|
成人a免费在线看|
91看片淫黄大片一级在线观看|
日韩高清一级片|
国产主播一区二区|
成人亚洲一区二区一|
日韩国产精品久久|
精品一区二区三区在线观看
|
成人毛片老司机大片|
天堂一区二区在线免费观看|
另类综合日韩欧美亚洲|
国产69精品久久久久毛片|
99九九99九九九视频精品|
美女精品一区二区|
国产宾馆实践打屁股91|
日本最新不卡在线|
国产精品亚洲第一区在线暖暖韩国
|
成人av网站在线|
日本aⅴ免费视频一区二区三区|
韩国毛片一区二区三区|
av高清久久久|
国产真实精品久久二三区|
成人美女视频在线观看|
裸体一区二区三区|
成人精品免费看|
精品亚洲成a人|
91网站最新网址|
国产成人午夜精品5599|
日本亚洲最大的色成网站www|
国产福利91精品一区二区三区|
91丨九色丨黑人外教|
国产剧情在线观看一区二区
|
日韩不卡一二三区|
成人一区二区在线观看|
久久国产麻豆精品|
91玉足脚交白嫩脚丫在线播放|
国产一区二区美女诱惑|
蜜臀av一区二区三区|
av资源网一区|
国产a久久麻豆|
精品一区二区三区免费|
日本伊人色综合网|
97se亚洲国产综合自在线不卡
|
国产乱码精品一区二区三|
日本va欧美va精品发布|
av亚洲精华国产精华|
国产99久久久精品|
国产一区二区日韩精品|
九九热在线视频观看这里只有精品|
9i在线看片成人免费|
大白屁股一区二区视频|
国产精品一级黄|
国产一区二区三区在线看麻豆|
麻豆成人在线观看|
奇米影视一区二区三区|
三级欧美在线一区|
水野朝阳av一区二区三区|
成人国产一区二区三区精品|
国产成人av影院|
国产99精品在线观看|
国产成人精品午夜视频免费|
国产精品一区二区视频|
国产伦精品一区二区三区免费|
精品午夜一区二区三区在线观看|
奇米影视在线99精品|
秋霞午夜av一区二区三区|
爽爽淫人综合网网站|
91麻豆swag|
欧美bbbbb|
久久精品国产一区二区三区免费看|
日本美女一区二区三区视频|
三级欧美韩日大片在线看|
日韩综合一区二区|
日本v片在线高清不卡在线观看|
日本不卡高清视频|
久久国产精品一区二区|
国内国产精品久久|
国产福利一区二区三区在线视频|
国产白丝精品91爽爽久久
|
久草在线在线精品观看|
久久99热狠狠色一区二区|
九九九久久久精品|
国产精品123|
成人高清免费观看|
三级欧美在线一区|
久久精品国产精品亚洲精品|
国产一本一道久久香蕉|
成人免费毛片app|
日韩电影一区二区三区四区|
久久99精品国产麻豆不卡|
国产成人午夜精品5599|
This is aparagraph with a list following it.
- ltem l
- ltem 2
- ltem 3
? ? ? ?
? ? ? ?
? ? ? ?
? ? ? ?在不同瀏覽器中,innerHTML返回的文本可能會有所不同。IE和Opera常常把所有標簽轉換為大寫,而Safari、Chrome和Firefox則以文檔中指定的形式返回HTML-包括空格和縮進。不要指望所有瀏覽器都會返回沒有絲毫差別的innerHTML值。
? ? ? ?在寫入信息時,innerHTML會將給定的字符串解析為DOM子樹,并用這個子樹替換所有的子節 點。由于賦給innerHTML的字符串會被當作HTML,因此其中包含的所有標簽都會按照瀏覽器處理 HTML的標準方式,被轉換成對應的元素(同樣,這個過程也會因瀏覽器而異)。如果像下面這樣, 只設置簡單的文本,那么結果就如同設置innerText -樣:
? ? ? ?div.innerHTML="Hello world!":
? ? ? ?如果為innerHTML設置的字符串中包含HTML代碼,結果可能就會大不一樣了。區別就在于innerText會轉義HTML語法字符,而innerHTML會解析它們。來看下面的例子:
? ? ? ?div.innerHTML="Hello&welcome, \"reader"!";
? ? ? ?執行這行代碼之后的結果是:
? ? ? ?
Hello & welcome, " reader"!
? ? ? ?在設置完innerHTML之后,馬上就可以像訪問文檔中的其他節點一樣訪問新生成的節點。
? ? ? ?設置innerHTML會導致瀏覽器將HTML字符串解析為對應的DOM樹。換句話說,設置完innerHTML之后再讀取它,將會得到一個差別很大的字符串。這個字符串不再是原始的
HTML代碼,而是根據原始HTML字符串創建的DOM子樹經過序列化之后的結果。
? ? ? ?innerHTML也有一些限制。首先,在多數瀏覽器中,通過innerHTML插入的
十余年專注于網站建設_小程序開發_APP開發,低調、敢創新、有情懷!



