zoukankan      html  css  js  c++  java
  • JavaScript基础BOM、DOM介绍和常用操作(5)

    day53

    参考:https://www.cnblogs.com/liwenzhou/p/8011504.html

    JavaScript引入方式

     由于BOM主要用于管理窗口与窗口之间的通讯,因此其核心对象是window

    BOM(alert、confirm、定时器)

    location对象

    window.location 对象用于获得当前页面的地址 (URL),并把浏览器重定向到新的页面。

    常用属性和方法:

    location.href  获取URL
    location.href="URL" // 跳转到指定页面
    location.reload() 重新加载页面


    弹出框

    可以在 JavaScript 中创建三种消息框:警告框、确认框、提示框。

    警告框

    警告框经常用于确保用户可以得到某些信息。

    当警告框出现后,用户需要点击确定按钮才能继续进行操作。

    语法:

    alert("你看到了吗?");

    
    

    确认框(了解即可)

    确认框用于使用户可以验证或者接受某些信息。

    当确认框出现后,用户需要点击确定或者取消按钮才能继续进行操作。

    如果用户点击确认,那么返回值为 true。如果用户点击取消,那么返回值为 false。

    语法:

    confirm("你确定吗?")
    
    

    提示框(了解即可)

    提示框经常用于提示用户在进入页面前输入某个值。

    当提示框出现后,用户需要输入某个值,然后点击确认或取消按钮才能继续操纵。

    如果用户点击确认,那么返回值为输入的值。如果用户点击取消,那么返回值为 null。

    语法:

    prompt("请在下方输入","你的答案")
    ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

    setTimeout()

    语法:

    var t=setTimeout("JS语句",毫秒)

    setTimeout() 方法会返回某个值。在上面的语句中,值被储存在名为 t 的变量中。假如你希望取消这个 setTimeout(),你可以使用这个变量名来指定它。

    setTimeout() 的第一个参数是含有 JavaScript 语句的字符串。这个语句可能诸如 "alert('5 seconds!')",或者对函数的调用,诸如 alertMsg()"。

    第二个参数指示从当前起多少毫秒后执行第一个参数(1000 毫秒等于一秒)。

    clearTimeout()

    语法:

    clearTimeout(setTimeout_variable)

    举个例子

    // 在指定时间之后执行一次相应函数
    var timer = setTimeout(function(){alert(123);}, 3000)
    // 取消setTimeout设置
    clearTimeout(timer);

    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

    setInterval()

    setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式。

    setInterval() 方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭。由 setInterval() 返回的 ID 值可用作 clearInterval() 方法的参数。

    语法:

    setInterval("JS语句",时间间隔)

    返回值

    一个可以传递给 Window.clearInterval() 从而取消对 code 的周期性执行的值。

    clearInterval()

    clearInterval() 方法可取消由 setInterval() 设置的 timeout。

    clearInterval() 方法的参数必须是由 setInterval() 返回的 ID 值。

    语法:

    clearInterval(setinterval返回的ID值)

    举个例子:

    // 每隔一段时间就执行一次相应函数
    var timer = setInterval(function(){console.log(123);}, 3000)
    // 取消setInterval设置
    clearInterval(timer);

    DOM

    直接查找

    document.getElementById           根据ID获取一个标签
    document.getElementsByClassName   根据class属性获取
    document.getElementsByTagName     根据标签名获取标签合集
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>DOM查找标签</title>
    </head>
    <body>
    
    <div id="d1">div</div>
    <p class="c1">p标签</p>
    <p class="c1">p标签2</p>
    <p class="c2">第二个p标签</p>
    
    </body>
    </html>

    分别查找id、类和标签名。

    间接查找

    复制代码
    parentElement            父节点标签元素
    children                 所有子标签
    firstElementChild        第一个子标签元素
    lastElementChild         最后一个子标签元素
    nextElementSibling       下一个兄弟标签元素
    previousElementSibling   上一个兄弟标签元素
    复制代码
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>DOM查找标签</title>
    </head>
    <body>
    
    <div id="d1">div</div>
    <p class="c1">p标签</p>
    <p class="c1">p标签2</p>
    <p class="c2">第二个p标签</p>
    
    <div id="d2">
        <div id="d3">d2里面的d3</div>
        <div id="d4">d2里面的d4</div>
        <div id="d5">d2里面的d5</div>
    </div>
    
    </body>
    </html>

    找所有子标签

    第一个子标签元素
    最后一个子标签元素

    下一个兄弟标签元素
    上一个兄弟标签元素
    d4的兄弟标签

    创建节点

    语法:

    document.createElement(标签名)

    示例:

    var divEle = document.createElement("div");

    添加节点

    语法:

    追加一个子节点(作为最后的子节点)在内部最后添加

    somenode.appendChild(newnode);

    把增加的节点放到某个节点的前边。 在内部指定标签前面添加

    somenode.insertBefore(newnode,某个节点);


    先创建一个img标签,document.createElement("img");
    把创建好的I'mEle添加到id是d1的标签内部,d1Ele.appendChild(imgEle)
    最后设置imgEle的src属性

    查看器中可以看出img标签已经放入。

    insertBefore举例:

    以上的a标签设置文本内容和属性

    以上内容总结:

    1. 找标签
                    1. 基本查找
                        1. 根据ID找标签(有且只能找到一个)
                            document.getElementById("ID值")
                        2. 根据class名字找(找到的可以是多个)
                            document.getElementsByClassName("class值")  
                        3. 根据标签名找(找到的可以是多个)
                            document.getElementsByTagName("标签名")
                    
                    2. 间接查找
                        1. 找父标签
                            document.parentElement
                        2. 找子标签(找到的可能是多个)
                            document.children
                        3. 第一个子标签
                        
                        4. 最后一个子标签
                        
                        5. 前一个兄弟标签
                        
                        6. 后一个兄弟标签
                2. 创建标签  *****
                    creatElement("标签名")
                
                3. 添加标签
                    1. 在内部的最后添加
                        appendChild("标签名")
                    2. 在内部的某个标签的前面插入
                        insertBefore(要插入的新标签, 哪个标签之前)
                4. 属性(内置属性)
                    .属性名="属性值"
                    
                    自定义的属性只能用:
                        .setAttribute("s9", "hao")
                        .getAttribute("s9")
                        .removeAttribute("s9")
                    
                5. 文本操作
                    1. 设置文本的内容
                        .innerText="<p>我是p标签</p>"        显示   <p>我是p标签</p>
                    2. 设置标签内容
                        .innerHTML="<p>我是p标签</p>"     显示      我是p标签
                    3. 获取值的区别
                        1. .innerHTML  --> 子标签和子标签的内容都取出来
                        2. .innerText  --> 只取标签之间的文本内容

     补充:

    innerText

    innerText只取标签之间的文本内容

    innerHTML

     innerHTML子标签和子标签的内容都取出来

    删除节点:

    语法:

    获得要删除的元素,通过父元素调用该方法删除。

    somenode.removeChild(要删除的节点)

    替换节点:

    语法:

    somenode.replaceChild(newnode, 某个节点);

    获取值操作

    语法:

    elementNode.value

    适用于以下标签:

    • .input   
    • .select
    • .textarea 
    复制代码
    var iEle = document.getElementById("i1");
    console.log(iEle.value);
    var sEle = document.getElementById("s1");
    console.log(sEle.value);
    var tEle = document.getElementById("t1");
    console.log(tEle.value);
    复制代码
    举例:
    02获取值相关
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>获取值相关</title>
    </head>
    <body>
    
    <form action="">
    
        <label>用户名
            <input type="text" id="i1" type="text">
        </label>
        <label><input name="gender" value="1" type="radio">
        </label>
        <label><input name="gender" value="1" type="radio">
        </label>
    
        <select name="from" id="s1">
            <option value="010">北京</option>
            <option value="021">上海</option>
            <option value="023">重庆</option>
            <option value="022">天津</option>
        </select>
    
        <textarea id="t1" name="memo"  cols="30" rows="10">
    
        </textarea>
    </form>
    
    </body>
    </html>

    效果:








  • 相关阅读:
    [Python接口自动化]从零开始学习python自动化(1):环境搭建
    转载:python + requests实现的接口自动化框架详细教程
    转载:selenium的wait.until()
    转载:selenium webdriver定位不到元素的五种原因及解决办法
    关于xpath语句完全正确,但是页面报错: no such element: Unable to locate element: {"method":"xpath","selector":"xpath"}
    BDD测试之selenium控制滚动条
    阿里云 -- 2万并发用户方案
    关于语音合成和识别
    在线浏览文档的方案
    关于全文搜索引擎
  • 原文地址:https://www.cnblogs.com/112358nizhipeng/p/10202022.html
Copyright © 2011-2022 走看看