jQuery动态创建html元素的常用方法汇总

一般来说,可以通过以下几种方式动态创建html元素:

1、使用jQuery创建元素的语法 
2、把动态内容存放到数组中,再遍历数组动态创建html元素 
3、使用模版

1.使用jQuery动态创建元素追加到jQuery对象上。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<meta http-equiv= "Content-Type" content= "text/html; charset=utf-8" />
   <title></title>
   <script src= "Scripts/jquery-1.10.2.js" ></script>
   <script type= "text/javascript" >
     $( function () {
       $( '<input />' , {
         id: 'cbx' ,
         name: 'cbx' ,
         type: 'checkbox' ,
         checked: 'checked' ,
         click: function () {
           alert( "点我了~~" );
         }
       }).appendTo($( '#wrap' ));
     });
   </script>
</head>
<body>
   <div id= "wrap" ></div>
</body>

运行效果如下图所示:

2.先把内容放到数组中,然后遍历数组拼接成html

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
<head>
<meta http-equiv= "Content-Type" content= "text/html; charset=utf-8" />
   <title></title>
   <script src= "Scripts/jquery-1.10.2.js" ></script>
   <style type= "text/css" >
     table {
       border: solid 1px red;
       border-collapse: collapse;
     }
  
     td {
       border: solid 1px red;
     }
   </style>
   <script type= "text/javascript" >
     $( function () {
       var data = [ "a" , "b" , "c" , "d" ];
       var html = '' ;
       for ( var i = 0; i < data.length; i ++) {
         html += "<td>" + data[i] + "</td>" ;
       }
       $( "#row" ).append(html);
     });
   </script>
</head>
<body>
   <table>
     <tr id= "row" ></tr>
   </table>
</body>
</html>

运行效果如下图所示:

3.使用模版生成html

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
<meta http-equiv= "Content-Type" content= "text/html; charset=utf-8" />
   <title></title>
   <script src= "Scripts/jquery-1.10.2.js" ></script>
   <script type= "text/javascript" >
     $( function () {
       var a = buildHTML( "a" , "我是由模版生成的" , {
         id: "myLink" ,
         href: "http://www.baidu.com"
       });
  
       $( '#wrap1' ).append(a);
  
       var input = buildHTML( "input" , {
         id: "myInput" ,
         type: "text" ,
         value: "我也是由模版生成的~~"
       });
  
       $( '#wrap2' ).append(input);
     });
  
     buildHTML = function (tag, html, attrs) {
       // you can skip html param
       if ( typeof (html) != 'string' ) {
         attrs = html;
         html = null ;
       }
       var h = '<' + tag;
       for (attr in attrs) {
         if (attrs[attr] === false ) continue ;
         h += ' ' + attr + '="' + attrs[attr] + '"' ;
       }
       return h += html ? ">" + html + "</" + tag + ">" : "/>" ;
     };
   </script>
</head>
<body>
   <div id= "wrap1" ></div>
   <div id= "wrap2" ></div>
</body>

运行效果如下图所示:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值