zoukankan      html  css  js  c++  java
  • jQuery操作DOM之修改DOM结构

    直接使用浏览器提供的API对DOM结构进行修改,不但代码复杂,而且要针对浏览器写不同的代码。

    有了jQuery,我们就专注于操作jQuery对象本身,底层的DOM操作由jQuery完成就可以了,这样一来,修改DOM也大大简化了。

    添加DOM

    要添加新的DOM节点,除了通过jQuery的html()这种暴力方法外,还可以用append()方法,例如:

    <div id="test-div">
        <ul>
            <li><span>JavaScript</span></li>
            <li><span>Python</span></li>
            <li><span>Swift</span></li>
        </ul>
    </div>

    如何向列表新增一个语言?首先要拿到<ul>节点:

    var ul = $('#test-div>ul');

    然后,调用append()传入HTML片段:

    ul.append('<li><span>Haskell</span></li>');
    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8" />
    <title>jQuery</title>
    <script src="/static/js/jquery-3.2.1.min.js"></script>
    </head>
    <body>
    <div id="test-div">
        <ul>
            <li><span>JavaScript</span></li>
            <li><span>Python</span></li>
            <li><span>Swift</span></li>
        </ul>
    </div>
    <script>
    'use strict';
    var ul = $('#test-div>ul');
    ul.append('<li><span>Haskell</span></li>');
    </script>
    
    </body>
    </html>

    结果:

     除了接受字符串,append()还可以传入原始的DOM对象,jQuery对象和函数对象:

    // 创建DOM对象:
    var ps = document.createElement('li');
    ps.innerHTML = '<span>Pascal</span>';
    // 添加DOM对象:
    ul.append(ps);
    
    // 添加jQuery对象:
    ul.append($('#scheme'));
    
    // 添加函数对象:
    ul.append(function (index, html) {
        return '<li><span>Language - ' + index + '</span></li>';
    });

    传入函数时,要求返回一个字符串、DOM对象或者jQuery对象。因为jQuery的append()可能作用于一组DOM节点,只有传入函数才能针对每个DOM生成不同的子节点。

    append()把DOM添加到最后,prepend()则把DOM添加到最前。

    另外注意,如果要添加的DOM节点已经存在于HTML文档中,它会首先从文档移除,然后再添加,也就是说,用append(),你可以移动一个DOM节点。

    如果要把新节点插入到指定位置,例如,JavaScript和Python之间,那么,可以先定位到JavaScript,然后用after()方法:

    var js = $('#test-div>ul>li:first-child');
    js.after('<li><span>Lua</span></li>');

    也就是说,同级节点可以用after()或者before()方法。

  • 相关阅读:
    Django【十五】pillow模块使用
    Django【十四】内置的anth认证
    Django【十三】form组件。
    Django【十二】中间价
    Django【十一】cookie-sesson
    Django【十】Ajax
    Django【八】多表操作
    Django【九】事务和锁
    python协程
    python多线程
  • 原文地址:https://www.cnblogs.com/ocean-boy/p/7410717.html
Copyright © 2011-2022 走看看