innerHtml的使用

本文通过一个简单的HTML页面示例,展示了如何使用JavaScript来获取并交换两个DOM元素的内容。示例中涉及了基本的HTML结构定义及JavaScript操作DOM的基本方法。

1.程序

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta charset="UTF-8">
 5 <title>Insert title here</title>
 6 <script type="text/javascript">
 7     window.onload=function(){
 8         var cityNode = document.getElementById("city");
 9         var gameNode = document.getElementById("game");
10         
11         //展示city的内容
12         alert(cityNode.innerHTML);
13         
14         //互换 #city 节点和 #game 节点中的内容. 
15         var tempHTML = cityNode.innerHTML;
16         cityNode.innerHTML = gameNode.innerHTML;
17         gameNode.innerHTML = tempHTML;
18     }
19 </script>
20 </head>
21 <body>
22 <body>
23     <p>你喜欢哪个城市?</p>
24     <ul id="city">
25         <li id="bj" name="BeiJing">北京</li>
26         <li>上海</li>
27         <li id="dj">东京</li>
28         <li id="se">首尔</li>
29     </ul><br><br>
30     
31     <p>你喜欢哪款单机游戏?</p>
32     <ul id="game">
33         <li id="rl">红警</li>
34         <li>实况</li>
35         <li>极品飞车</li>
36         <li>魔兽</li>
37     </ul><br><br>
38 </body>
39 </html>

 

2.运行结果

  

  互换后的结果:

  

 

### 使用 `innerHTML` 属性的详细说明 在 JavaScript 中,`innerHTML` 是一个非常常用的属性,用于获取或设置指定元素的内容。以下是关于如何使用 `innerHTML` 属性的详细说明: #### 1. 获取元素内容 可以通过 `document.getElementById()` 方法获取指定的 HTML 元素对象,然后使用 `.innerHTML` 属性读取该元素的内容。 ```javascript function getInnerHTML() { var element = document.getElementById("example"); alert(element.innerHTML); // 显示元素的内容 } ``` 上述代码中,通过 `document.getElementById("example")` 获取了 ID 为 `example` 的元素,并通过 `.innerHTML` 属性读取其内容[^2]。 #### 2. 设置元素内容 除了读取内容外,还可以通过 `innerHTML` 属性修改元素的内容。例如: ```javascript document.getElementById('innerHTMLtxt').innerHTML = "奇葩天地网欢迎你!"; ``` 此代码将 ID 为 `innerHTMLtxt` 的元素内容替换为 `"奇葩天地网欢迎你!"`[^1]。 #### 3. 替换复杂内容 `innerHTML` 不仅可以设置纯文本,还可以设置包含 HTML 标签的内容。例如: ```javascript var mychar = document.getElementById("con"); mychar.innerHTML = "<strong>hello WorldW!</strong>"; ``` 上述代码将 ID 为 `con` 的元素内容替换为带有 `<strong>` 标签的加粗文本[^3]。 #### 4. 注意事项 - **安全性问题**:如果直接将用户输入的内容赋值给 `innerHTML`,可能会导致 XSS(跨站脚本攻击)。因此,在处理用户输入时需要格外小心。 - **性能问题**:频繁修改 `innerHTML` 可能会影响页面性能,尤其是在处理大量 DOM 元素时。 ### 示例代码 以下是一个完整的示例,展示如何使用 `innerHTML` 获取和设置元素内容: ```html <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>innerHTML 示例</title> <script type="text/javascript"> function showOriginalContent() { var element = document.getElementById("content"); alert("原始内容: " + element.innerHTML); } function updateContent() { var element = document.getElementById("content"); element.innerHTML = "新内容"; } </script> </head> <body> <h2 id="content">初始内容</h2> <p><button onclick="showOriginalContent()">显示原始内容</button></p> <p><button onclick="updateContent()">更新内容</button></p> </body> </html> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值