草庐IT

JavaScript(WebAPI)

熬夜磕代码丶 2023-04-17 原文

文章目录

一、WebAPI是什么?

我们前面刚刚学习过JS语法,我们可以把JS分为三大部分:
ECMAScript:基础语法
DOM API:操作页面结构
BOM API:操作浏览器

Web API 包含了 DOM + BOM,Web API都是浏览器给js代码提供的功能(如果浏览器不同,api所呈现的行为也可能有所差异)

二、DOM基本概念

DOM(Document Object Model):文档对象模型,这里文档指的是html,对象指的是js中的对象,我们可以把html的每个标签都可以映射到js中的每一个对应的对象,js对象修改对应的属性,就可以影响标签的展示

DOM树

一个网页页面的结构是一个树型结构,我们也成为DOM树,结构如下:


文档:一个页面就是一个文档,使用document表示
元素:网页中的所有标签都成为元素,使用element表示
节点:网页中所有的内容都可以称为 节点(标签节点, 注释节点, 文本节点, 属性节点等). 使用 node表示.
这些概念在JS代码中对应一个个对象

选中页面元素

这个工作类似于我们CSS选择器的功能
querySelector 能够复用我们CSS选择器,快捷准确的获取到元素对象

let element = document.querySelector(CSS选择器);

我们来初体验一下querySelector,首先我们准备一个html文件

<div class="a">aaa</div>


大家需要注意:我们在使用querySelector的使用并不是直接使用querySelector,而是使用document调用querySelector,document是浏览器中的全局对象,任何一个页面都会有一个document对象

<script>
        let elem = document.querySelector('.a');
        console.log(elem);
    </script>


如果我们有多个.a那么我们默认选中的是第一个,如果想都选,需要使用querySelectorAll(返回一个数组)

这里针对不同的选择器选择的方式不同

三、事件

事件就是针对用户的操作进行的一些相应
时间三要素:
事件源:那个元素触发的
事件类型:选中,点击,键盘按下,修改等
事件处理:事件发生之后要执行那个代码

最简单的一个方式:

<div class="a" onclick="alert('hello webapi')">aaa</div>


直接在元素中使用onXXX的方法来绑定一个事件处理程序

    <script>
        let div = document.querySelector(".a");
        div.onclick = function() {
            alert("hello");
        }
    </script>


我们的这里的function匿名函数相当于一个回调函数,不需要我们程序员自己调用,而是浏览器在触发事件时进行调用

操作元素

1.获取/修改元素内容
首先获取到该元素,使用innerHTML属性拿到元素里的内容,修改该属性,就会影响到界面的显示

    <div class="a">aaa</div>
    <script>
        let div = document.querySelector(".a");
        div.onclick = function() {
            div.innerHTML = div.innerHTML + 'a';
        }
    </script>

此处我们每点击一下,末尾就加a

2.获取/修改元素属性
html的属性也会映射到js对象中


console.dir(js对象);

打印Js对象所有属性
3.获取/修改表单元素属性
表单元素(input,textarea,select)这些特别的元素是普通的标签没有的

属性作用
valueinput的值
typeinput的类型
    <input type="text">
    <button>点我一下</button>
    <script>
        let input = document.querySelector('input');
        let button = document.querySelector('button');
        button.onclick = function() {
            console.log(input.value);
        }
    </script>

输入框输入什么,我们在控制台打印什么

大家需注意innerHTML与这里的input.value的区别:
innerHTML得到的是标签的内容(开始标签和结束标签中间夹着的内容),input标签是单标签,是没有内容的
我们来实现一个给input里的的数字,每按一次按钮,就给数字+1

我们给Input内输入1,开始按按钮


我们发现并没有加1,因为我们value属性是一个字符串,我们这里变成字符串拼接了,我们这里需要把字符串转成整数(parseInt)

    <input type="text">
    <button>点我一下</button>
    <script>
        let input = document.querySelector('input');
        let button = document.querySelector('button');
        button.onclick = function() {
            let value = parseInt(input.value);
            value += 1;
            input.value = value;
        }
    </script>


此时就实现功能了
我们的type属性可以实现显示和隐藏密码功能

    <input type="password">
    <button>显示密码</button>
    <script>
        let input = document.querySelector('input');
        let button = document.querySelector('button');
        button.onclick = function() {
            if(input.type == 'text') {
                input.type = 'password';
                button.innerHTML = '显示密码';
            }else {
                input.type = 'text';
                button.innerHTML = '隐藏密码';
            }
        }
    </script>



4.获取/修改样式属性
1.修改内联样式(修改style属性的值)

    <div style="font-size: 20px;">
        点我放大
    </div>
    <script>
        let div = document.querySelector('div');
        div.onclick = function() {
            let size = parseInt(div.style.fontSize);
            size += 5;
            div.style.fontSize = size + 'px';
        }
    </script>


这里我们需要注意CSS与JS中字体大小属性是有所不同的,CSS是脊柱命名法,我们JS是驼峰命名法。

因为我们在CSS设置的字体大小单位为px,所以我们先转为Int,然后在转回px.

2.修改元素应用的CSS类名
我们这里实现一个切换夜间模式,我们首先先准备两个模式

    <style>
        .light {
            /* 日间模式 */
            color: black;
            background-color: white;
        }
        .dark {
            /* 夜间模式 */
            color: white;
            background-color: black;
        }
    </style>

具体功能实现:

    <div class = 'light'>切换夜间模式</div>
    <script>
        let div = document.querySelector('.light');
        div.onclick = function() {
            if(div.className == 'dark') {
            div.className = 'light';
            div.innerHTML = '切换夜间模式';
        }else {
            div.className = 'dark';
            div.innerHTML = '切换日间模式';
        }
        }
    </script>


四、操作节点

新增元素

新增节点一般分为两个步骤:
1.创建元素节点
2.把元素节点插入到DOM树中

使用 createElement 方法来创建一个元素

    <script>
        let input = document.createElement('input');
        input.type = 'text';
        input.value = 123456;
        console.log(input);
    </script>
</body>


使用appendChild 插入到DOM树中

    <div class = 'a'>请输入:</div>
    <script>
        let input = document.createElement('input');
        input.type = 'text';
        input.value = 123456;
        console.log(input);
        let div = document.querySelector('.a');
        div.appendChild(input);
    </script>


appendChild是默认插入在子元素末尾的,insertBefore可以将元素加到指定子元素的前面

删除元素

使用 removeChild 删除子节点,我们将刚刚加入的input标签删除

返回值为该被删除节点
被删除节点只是从 dom 树被删除了, 但是仍然在内存中, 可以随时加入到 dom 树的其他位置.
如果上例中的 child节点 不是 element 节点的子节点,则该方法会抛出异常.

五、猜数字

我们实现一个网页版的猜数字
1.生成一个1 - 100之间的随机数字
2.用户输入一个数字
3.判断用户输入的数字大小关系给出提示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>猜数字</title>
</head>
<body>
    <div>请输入要猜的数字:</div>
    <input type="text" >
    <button>提交</button>
    <!-- 显示提示信息 -->
    <div class="result">

    </div>
    <script>
        //生成一个1 - 100之间的随机数
        let toGuess = parseInt(100 * Math.random()) + 1; 
        // 因为Math.rondom()生成的是[0,1)之间的随机数,我们需要进行转换
        console.log(toGuess);

        //进行猜数字操作
        let button = document.querySelector('button');
        let input = document.querySelector('input');
        let information = document.querySelector('.result');
        button.onclick = function() {
            //取出输入框内容
            if(input.value == '') {
                return;
            }
            let inputNum = parseInt(input.value);
            if(inputNum < toGuess) {
                information.innerHTML = '猜小了';
            }else if(inputNum > toGuess) {
                information.innerHTML = '猜大了';
            }else {
                information.innerHTML = '恭喜你,猜对了!';
            }
        }
    </script>
</body>
</html>



六、表白墙

<body>
    <h1>表白墙</h1>
    <span>谁: </span>
    <input type="text">
    <span>对谁: </span>
    <input type="text">
    <span>说: </span>
    <input type="text">
    <button>提交</button>
</body>


这算什么表白墙,下面的才是我们要实现的

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>表白墙</title>
    <style>

        * {
            /* 消除浏览器默认样式 */
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }
        .container {
            width: 600px;
            margin: 20px auto;
        }

        h1 {
            text-align: center;
        }

        p {
            text-align: center;
            color: #666;
            margin: 20px auto;
        }

        .row {
            /* 开启弹性布局 */
            display: flex;
            height: 40px;
            /* 水平方向居中 */
            justify-content: center;
            /* 竖直方向居中 */
            align-items: center;
        }
        .row span {
            width: 80px;
        }
        .row input {
            width: 200px;
            height: 30px;
        }

        .row button {
            width: 280px;
            height: 30px;
            color: white;
            background-color: orange;
            /* 去掉默认边框 */
            border: none;
            border-radius: 3px;
        }

        .row button:active {
            background-color: black;
        }
    </style>
</head>
<body>
    <div class="container">
        <h1>表白墙</h1>
        <p>输入内容后点击提交,信息将显示到下方表格</p>
        <div class="row">
            <span>谁: </span>
            <input type="text">
        </div>
        <div class="row">
            <span>对谁: </span>
            <input type="text">
        </div>
        <div class="row">
            <span>说: </span>
            <input type="text">
        </div>
        <div class="row">
            <button>提交</button>
        </div>
    </div>

    <script>
        // 实现将提交的内容呈现在页面显示
        let containerDiv = document.querySelector('.container');
        let inputs = document.querySelectorAll('input');
        let button = document.querySelector('button');
        button.onclick = function() {
            //分别获取三个输入框的内容
            let from = inputs[0].value;
            let to = inputs[1].value;
            let msg = inputs[2].value;
            //构建一个新的div
            let rowDiv = document.createElement('div');
            rowDiv.className = 'row';
            rowDiv.innerHTML = from + ' 对 ' + to + ' 说 ' + msg;
            containerDiv.appendChild(rowDiv);
            // 完成提交后 情况输入框内的内容
            for(let input of inputs) {
                input.value = '';
            }
        }
    </script>
</body>
</html>

有关JavaScript(WebAPI)的更多相关文章

  1. ruby-on-rails - 使用 javascript 更改数据方法不会更改 ajax 调用用户的什么方法? - 2

    我遇到了一个非常奇怪的问题,我很难解决。在我看来,我有一个与data-remote="true"和data-method="delete"的链接。当我单击该链接时,我可以看到对我的Rails服务器的DELETE请求。返回的JS代码会更改此链接的属性,其中包括href和data-method。再次单击此链接后,我的服务器收到了对新href的请求,但使用的是旧的data-method,即使我已将其从DELETE到POST(它仍然发送一个DELETE请求)。但是,如果我刷新页面,HTML与"new"HTML相同(随返回的JS发生变化),但它实际上发送了正确的请求类型。这就是这个问题令我困惑的

  2. ruby - 在 Mechanize 中使用 JavaScript 单击链接 - 2

    我有这个:AccountSummary我想单击该链接,但在使用link_to时出现错误。我试过:bot.click(page.link_with(:href=>/menu_home/))bot.click(page.link_with(:class=>'top_level_active'))bot.click(page.link_with(:href=>/AccountSummary/))我得到的错误是:NoMethodError:nil:NilClass的未定义方法“[]” 最佳答案 那是一个javascript链接。Mechan

  3. javascript - jQuery 的 jquery-1.10.2.min.map 正在触发 404(未找到) - 2

    我看到有关未找到文件min.map的错误消息:GETjQuery'sjquery-1.10.2.min.mapistriggeringa404(NotFound)截图这是从哪里来的? 最佳答案 如果ChromeDevTools报告.map文件的404(可能是jquery-1.10.2.min.map、jquery.min.map或jquery-2.0.3.min.map,但任何事情都可能发生)首先要知道的是,这仅在使用DevTools时才会请求。您的用户不会遇到此404。现在您可以修复此问题或禁用sourcemap功能。修复:获取文

  4. ruby-on-rails - 我将 Rails3 与 tinymce 一起使用。如何呈现用户关闭浏览器javascript然后输入xss? - 2

    我有一个用Rails3编写的站点。我的帖子模型有一个名为“内容”的文本列。在帖子面板中,html表单使用tinymce将“content”列设置为textarea字段。在首页,因为使用了tinymce,post.html.erb的代码需要用这样的原始方法来实现。.好的,现在如果我关闭浏览器javascript,这个文本区域可以在没有tinymce的情况下输入,也许用户会输入任何xss,比如alert('xss');.我的前台会显示那个警告框。我尝试sanitize(@post.content)在posts_controller中,但sanitize方法将相互过滤tinymce样式。例如

  5. ruby - 使用 Selenium WebDriver 启用/禁用 javascript - 2

    出于某种原因,我必须为Firefox禁用javascript(手动,我们按照提到的步骤执行http://support.mozilla.org/en-US/kb/javascript-settings-for-interactive-web-pages#w_enabling-and-disabling-javascript)。使用Ruby的SeleniumWebDriver如何实现这一点? 最佳答案 是的,这是可能的。而是另一种方式。您首先需要查看链接Selenium::WebDriver::Firefox::Profile#[]=

  6. ruby - Watir-Webdriver 是否支持点击目标为 javascript 的链接? - 2

    我是Ruby和Watir-Webdriver的新手。我有一套用VBScript编写的站点自动化程序,我想将其转换为Ruby/Watir,因为我现在必须支持Firefox。我发现我真的很喜欢Ruby,而且我正在研究Watir,但我已经花了一周时间试图让Webdriver显示我的登录屏幕。该站点以带有“我同意”区域的“警告屏幕”开头。用户点击我同意并显示登录屏幕。我需要单击该区域以显示登录屏幕(这是同一页面,实际上是一个表单,只是隐藏了)。我整天都在用VBScript这样做:objExplorer.Document.GetElementsByTagName("area")(0).click

  7. 网页设计期末作业,基于HTML+CSS+JavaScript超酷超炫的汽车类企业网站(6页) - 2

    🎉精彩专栏推荐💭文末获取联系✍️作者简介:一个热爱把逻辑思维转变为代码的技术博主💂作者主页:【主页——🚀获取更多优质源码】🎓web前端期末大作业:【📚毕设项目精品实战案例(1000套)】🧡程序员有趣的告白方式:【💌HTML七夕情人节表白网页制作(110套)】🌎超炫酷的Echarts大屏可视化源码:【🔰Echarts大屏展示大数据平台可视化(150套)】🔖HTML+CSS+JS实例代码:【🗂️5000套HTML+CSS+JS实例代码(炫酷代码)继续更新中…】🎁免费且实用的WEB前端学习指南:【📂web前端零基础到高级学习视频教程120G干货分享】🥇关于作者:💬历任研发工程师,技术组长,教学总监;

  8. ruby-on-rails - 在页面的最底部包含 javascript 文件 - 2

    我有一个Rails应用程序。还有一个javascript(javascript1.js)文件必须包含在每个View的最底部。我把它放在/assets/javascripts文件夹中。Application.js包含以下代码//=requirejquery//=requirejquery_ujs//=someotherfiles//=require_directory.即使Application.js中不包含javascript1.js,它也会自动包含,不是吗?那么我怎样才能做我想做的事呢? 最佳答案 单独定义、包含和执行您的java

  9. ruby-on-rails - 为 rails 中的 javascript 生成完整的 url(类似于 javascript_path,但是是 url) - 2

    如何生成指向javascript文件的绝对链接。我想应该有类似下面的东西(不幸的是它似乎不可用):javascript_url'main'#->'http://localhost:3000/javascripts/main.js'代替:javascript_path'main'#->'/javascripts/main.js'我需要绝对URL,因为该javascript文件将用于书签。另外我需要相同的css文件。谢谢,德米特里。 最佳答案 javascript和css文件的绝对URL现在在Rails4中可用ActionView::H

  10. ruby - 处理在 keyup 事件上发生的 javascript 弹出窗口 - 2

    我在HTML页面上有一个文本字段,用于检查您是否输入了1到365之间的值。如果用户输入了无效值,如非数字字符或不在范围内的值,它显示一个弹出窗口。我在watirwiki上看到有一个select_no_wait方法,用于在您从列表中选择无效值时关闭弹出窗口。处理键盘事件时出现的弹出窗口的好方法是什么?我是否需要按照select_no_wait方法的实现方式进行操作,或者我们是否可以启动一个不同的进程来消除调用set方法时可能出现的弹出窗口。带有Javascript验证函数的HTML文件示例如下:varnum=0functionvalidate(e){varcharPressed=Stri

随机推荐