7.动态创建DOM

8.innerText  innerHTML  value

7+8 练习:案例:点击按钮动态增加网站列表,分两列,第一列为网站的名字,第二列为带网站超链接的网站名。增加三行常见网站。浏览器兼容性问题,见备注。动态产生的元素,查看源代码是看不到的。通过DebugBar→Dom→文档→HTML可以看到。

练习1:练习:动态生成n个文本框 (每3个一行)

练习2:无刷新评论。

7.动态创建DOM


document.write只能在页面加载过程中才能动态创建。
可以调用document的createElement方法来创建具有指定标签的DOM对象,然后通过调用某个元素的appendChild();方法将新创建元素添加到相应的元素下。//父元素对象.removeChild(子元素对象);删除元素。

function showIt() {
var divMain = document.getElementById("divMain");
var btn = document.createElement("input");
btn.type = "button";
btn.value = "我是动态的!";
divMain.appendChild(btn);
}
<div id="divMain"></div>
<input type="button" value="ok" onclick="showit()" />

 

8.innerText  innerHTML  value


value 获取表单元素的值

几乎所有DOM元素都有innerText、innerHTML属性(注意大小写),分别是元素标签内内容的文本表示形式和HTML源代码,这两个属性是可读可写的。//FF不支持innerText,在FF下用textContent属性。也可以用innerHTML设置普通文本。

示例:代码见备注1。(innerText与innerHTML区别。)

隐藏行号 复制代码 ? 这是一段程序代码。
  • <!DOCTYPE html>
  • <html xmlns="http://www.w3.org/1999/xhtml">
  • <head>
  •     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  •     <title></title>
  •     <script type="text/javascript">
  •         function f1() {
  •             var div = document.getElementById("d1");
  •             var div2 = document.getElementById("d2");
  •             //innerText会对尖括号进行转义
  •             div.innerText = "<b>欢迎</b>光临<font color='red'>唐三三</font>部落";
  •             div2.innerHTML = "<b>欢迎</b>光临<font color='red'>唐三三</font>部落";
  •         };
  •         function f2() {
  •             var div2 = document.getElementById("d3");
  •             //移除html标签  
  •             alert(div2.innerText);
  •         };
  •         
  •         function f3() {
  •             var div2 = document.getElementById("d3");
  •             //移除html标签  
  •             alert(div2.innerHTML);
  •         };
  •     </script>
  • </head>
  • <body>
  •     <div id="d1">1234567890<input type="text" /></div>
  •     <div id="d2">1234567890<input type="text" /></div>
  •     <input id="btn" type="button" value="点击" onclick="f1()" />
  •     <div id="d3"><b>欢迎</b>光临<font color='red'>唐三三</font>部落</div>
  •     <input id="btn_2" type="button" value="弹窗innerText" onclick="f2()" />
  •     <input id="btn_3" type="button" value="弹窗innerHTML" onclick="f3()" />
  • </body>
  • </html>
  • 用innerHTML也可以替代createElement,属于简单、粗放型、后果自负的创建。

    示例:

    function createlink() {
    var divMain = document.getElementById("divMain");
                divMain.innerHTML = "<a href='http://www.cnblogs.com/tangge/p/3172689.html'>7.动态创建DOM + 8.innerText innerHTML value - 【唐】三三 - 博客园</a>";
            }

     

    7+8 练习:


    案例:点击按钮动态增加网站列表,分两列,第一列为网站的名字,第二列为带网站超链接的网站名。增加三行常见网站。浏览器兼容性问题,见备注。动态产生的元素,查看源代码是看不到的。通过DebugBar→Dom→文档→HTML可以看到。

    隐藏行号 复制代码 ? 这是一段程序代码。
  • <!DOCTYPE html>
  • <html xmlns="http://www.w3.org/1999/xhtml">
  • <head>
  •     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  •     <title></title>
  •     <script type="text/javascript">
  •         window.onload = function () {
  •             var json = [
  •                 { "name": "cnblog", "site": "http://www.cnblogs.com" },
  •                 { "name": "cnbeat", "site": "http://www.cnbeat.com" },
  •                 { "name": "qiushibaike", "site": "http://www.qiushibaike.com" }
  •             ];
  •             var div = document.getElementById("d1");
  •             //动态创建table
  •             var table = document.createElement("table");
  •             //把table添加到div
  •             div.appendChild(table);
  •             table.border = 1;
  •             table.width = "350px";
  •             for (var i = 0; i < json.length; i++) {
  •                 var site = json[i];
  •                 //创建tr
  •                 var tr = document.createElement("tr");
  •                 table.appendChild(tr);
  •                 //创建第1列td
  •                 var td = document.createElement("td");
  •                 td.innerHTML = site.name;
  •                 tr.appendChild(td);
  •                 //相当于new一个td(第2列)
  •                 td = document.createElement("td");
  •                 td.innerHTML = site.site;
  •                 tr.appendChild(td);
  •             }
  •         }
  •     </script>
  • </head>
  • <body>
  •     <div id="d1"></div>
  • </body>
  • </html>


  • 练习1:练习:动态生成n个文本框 (每3个一行)

    隐藏行号 复制代码 ? 这是一段程序代码。
  • <!DOCTYPE html>
  • <html xmlns="http://www.w3.org/1999/xhtml">
  • <head>
  •     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  •     <title></title>
  •     <script type="text/javascript">
  •         function create() {
  •             var number = document.getElementById("text").value;
  •             var div = document.getElementById("div1");
  •             div.innerHTML = "";
  •             //循环从1开始(方便下面余3取0)
  •             for (var i = 1; i <= parseInt(number) ; i++) {
  •                 //创建第1列td
  •                 //创建input type="text"
  •                 var input = document.createElement("input");
  •                 input.type = "text";
  •                 input.value = "text" + i;
  •                 input.length = "30px";
  •                 div.appendChild(input);
  •                 //每3个空一行
  •                 if (i % 3 == 0) {
  •                     var br = document.createElement("br");
  •                     div.appendChild(br);
  •                 }
  •             }
  •         }
  •     </script>
  • </head>
  • <body>
  •     <div id="div">
  •         人数:<input id="text" type="text" value="1" />
  •         <input type="button" value="生成" onclick="create()" />
  •     </div>
  •     <div id="div1"></div>
  • </body>
  • </html>

  • 练习2:无刷新评论。

    <table>

        <tr><td>猫猫:</td><td>沙发耶!</td></tr>

    </table>

    昵称:<input type="text" /><br />

    <textarea id=“txt”></textarea><br />

    <input type="button" value="评论" />

    隐藏行号 复制代码 ? 这是一段程序代码。
  • <!DOCTYPE html>
  • <html xmlns="http://www.w3.org/1999/xhtml">
  • <head>
  •     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  •     <title></title>
  •     <script type="text/javascript">
  •         function note() {
  •             var name = document.getElementById("txtname").value;
  •             var content = document.getElementById("txt").value;
  •             
  •             var row = document.createElement("tr");
  •             var tb = document.getElementById("tb");
  •             tb.appendChild(row);
  •             var td = document.createElement("td");
  •             row.appendChild(td);
  •             td.innerHTML = name;
  •             
  •             td = document.createElement("td");
  •             row.appendChild(td);
  •             td.innerHTML = content;
  •             
  •             
  •         }
  •     </script>
  • </head>
  • <body>
  •     <table id="tb">
  •         <tr>
  •             <td >猫猫:</td>
  •             <td>沙发耶!</td>
  •         </tr>
  •     </table>
  •     昵称:<input id="txtname" type="text" /><br />
  •     <textarea id="txt"></textarea><br />
  •     <input type="button" value="评论" onclick="note()" />
  • </body>
  • </html>
  • DOM – 7.动态创建DOM + 8.innerText innerHTML value的更多相关文章

    1. JavaScript DOM编程基础精华02(window对象的属性,事件中的this,动态创建DOM,innerText和innerHTML)

      window对象的属性1 window.location对象: window.location.href=‘’;//重新导航到新页面,可以取值,也可以赋值. window.location.reloa ...

    2. JS,Jquery,ExtJs不同脚本动态创建DOM对象

      好久不来写东西了,这段时间太慢了,闲了下来看了几篇文章,觉得很好,同时也许咱们大家都能遇到,所以就把它记录下来... 简单使用JavaScript.JQuery.ExtJs进行DOM对象创建的测试,主 ...

    3. jQuery – 7.动态创建Dom、删除节点

      动态创建Dom节点     1.使用$(html字符串)来创建Dom节点     2.append方法用来在元素的末尾追加元素     案例:动态生成网站列表     3.prepend,在元素的开始 ...

    4. 动态创建dom元素

      效果图如上所示: 思维nav:就相当于qq空间发表动态(说说),在输入框里输入内容,点击提交(发表),内容就呈现在下面的动态栏里.我这里是准备写一个招聘的app,大家可以随便想象下哪些情况会遇到动态创 ...

    5. JS、JQuery和ExtJs动态创建DOM对象

      做了个简单使用JavaScript.JQuery.ExtJs进行DOM对象创建的测试,主要是使用JavaScript.JQuery.ExtJs动态创建Table对象.动态Table数据填充.多选控制. ...

    6. Vue.js源码解析-Vue初始化流程之动态创建DOM

      目录 前言 一._update 如何判断是初始化还是更新操作? 二.patch 2.1 patch 定义 2.2 初始化的 patch 三.createElm 动态创建DOM 3.1 创建组件节点 3 ...

    7. DOM操作-动态创建网页元素

      动态创建新的DOM元素,是JavaScript操作网页对象模型的重要手段之一 代码: <!DOCTYPE html> <html> <head> <title ...

    8. js学习-DOM之动态创建元素的三种方式、插入元素、onkeydown与onkeyup两个事件整理

      动态创建元素的三种方式: 第一种: Document.write(); <body> <input type="button" id="btn" ...

    9. jQuery动态创建DOM节点

      var SKU=$("#SKU"); // 通过ID查找到指定表格 var oTable=SKU[0]; // 获取第一个表格 // 获取正文tbody元素 var tBodies ...

    随机推荐

    1. 破解TexturePacker加密资源

      http://blog.csdn.net/ynnmnm/article/details/38392795 最近我们要开一个新项目,UI与交互打算借鉴当前正火的<圣火英雄传>,程序开发为了和 ...

    2. jquery获取和设置表单数据

      1.需求 正好做到设置和获取表单数据的功能,做个整理 2.计划安排 3.计划实施 1.获取值 <!--1获取普通文本框的值--> <input type="text&quo ...

    3. WebStorm设置左侧菜单栏背景色和样式

      WebStrom一直以来都是默认的白色主题,今天想修改了下主题皮肤,结果导致左侧项目资源栏和顶部菜单栏也变成了黑色,结果无法改变回来,网上查了各种帖子,居然也没找到解决方法,自己研究了半天,终于搞定了 ...

    4. jquery为新增元素添加事件

      <script type="text/javascript"> var $id=1; $(function(){ $(".hehe").click( ...

    5. IP转换成LONG 的 问题

      如何将四个字段以点分开的IP网络址协议地址转换成整数呢?PHP里有这么一个函数ip2long.比如 <?php echo ip2long("10.2.1.3"); ?> ...

    6. Calico在Docker中的搭建

      一,Multi-host网络需求 开始之前推荐两篇文章 http://xelatex.github.io/2015/11/15/Battlefield-Calico-Flannel-Weave-and ...

    7. PyCharm 4.0.6 注册码

      Professional Edition版本比Free版本多了很多东西,比如 Web development,Django等等,重新下了Professional版本,虽然是只30天免费,但是到时候重装 ...

    8. fork详解

      [本文链接] http://www.cnblogs.com/hellogiser/p/fork.html [代码] 下面的代码输出多少个-?  C++ Code  123456789101112131 ...

    9. Spring AOP基于配置文件的面向方法的切面

      Spring AOP基于配置文件的面向方法的切面 Spring AOP根据执行的时间点可以分为around.before和after几种方式. around为方法前后均执行 before为方法前执行 ...

    10. linux shell脚本通过参数名传递参数值

      平常在写shell脚本都是用$1,$2....这种方式来接收参数,然而这种接收参数的方式不但容易忘记且不易于理解和维护.Linux常用的命令都可指定参数名和参数值,然而我们怎样才能给自己的shell脚 ...