前端三剑客 —— JavaScript (第九节)

目录

内容回顾:

1.事件解除

2. Ajax

jQuery选择器

回顾CSS选择器

CSS选择

1.基本选择器

2.包含选择器

3.伪类选择器

4.伪元素选择器

5.属性选择器

jQuery 库

jQuery 动画

系统动画

自定义动画

常见API操作


内容回顾:

1.事件解除

         如果是使用DOM0的方式来进行事件绑定时,则解除绑定只需要让这个对象的事件 = null

        如果是使用DOM2的方式来进行事件绑定时,则解除绑定需要做两舰事件:

                1)将事件处理函数独立出来

                2)使用removeEventListener(‘事件类型’,独立出来函数)

         如果阻止冒泡,我们采用的是stopPragation()这个方法来进行阻止冒泡

2. Ajax

它是来提高我们的用户体验,但是它不利于搜索引擎的优化。使用它需要做以下几步:

        1.创建XMLHttpRequest()对象,这个对象是Ajax的核心对象,所有的操作都是基于这个对象来产生的。如 let xhr = new XMLHttpRequest()

        2.打开链接,使用的是SMLHttpRequest对象的open()方法,这个方法有三个参数:第一个参数是请求提交方式(GET | POST);第二个参数是请求服务器的URL;第三个参数是请求的方式(true | false),默认是true 表示异步请求

        3.发送请求,使用的是XMLHttpRequest 对象的send()方法,如果是get 请求,则参数可以写在url上,如果是post请求则需要把参数写在此方法的参数位置

        4.处理响应,使用的是XMLHttpRequest对象的onreadystatechange事件,它需要有一个回调函数,在这个回调函数数中我们先走判断readyState属性的值,以及判断status属性的值。

                -- xhr.readyStatus 属性有以下几个值:

                    0:这是在打开链接之前,即创建好xhr对象

                    1:表示打开链接

                    2:表示发送请求之前

                    3:服务器接受到请求,在响应之前

                    4:服务器接收到请求,并响应给客户端

                --  xhr.status 属性有以下一些值:

                    200:表示请求成功响应

                    301:表示响应重定向

                    404:表示资源没有找到

                    401:表示没有权限

                    500:表示服务端有错

                     ……..

        -- xhr.responseText 属性来获取到服务端响应回来的数据

jQuery

初体验

要使用jQuery库,我们需要有以下几个步骤:

1.将jQuery库文件下载到本地(或者使用网络地址)

2.将下载好的jQuery库文件添加到页面中

3.创建jQuery对象

4.使用jQuery

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <title>jQuery简单使用</title>

    <style>

        .box {

            width: 400px;

            height: 30px;

            background: #243A64;

            color: white;

        }

    </style>

</head>

<body>

<div class="box"></div>

<script src="js/jQuery-3.7.1.js"></script>

<script>

    /*

    $(function () {

        // 1. 获取div对象,并设置内容

        $('.box').html('hello jQuery')

    })

     */

    $(document).ready(function () {

        //$('.box').html('hello jQuery')

        console.log('jQuery1')

    })

    $(document).ready(function () {

        console.log('jQuery2')

    })

    $(document).ready(function () {

        console.log('jQuery3')

    })

    $(function () {

        console.log('jQuery11')

    })

    $(function () {

        console.log('jQuery22')

    })

    window.onload = function () {

        console.log('页面加载完成1')

    }

    window.onload = function () {

        console.log('页面加载完成2')

    }

</script>

</body>

</html>

jQuery选择器

jQuery提供了强大的选择器,它的选择器完美的兼容了CSS选择器。换句话说,我们完全可以在jQuery中使用CSS选择器来进行选择。

回顾CSS选择器

CSS选择

1.基本选择器

        1.1 id选择器,#

        1.2 类选择器,.

        1.3 标签选择器

        1.4 通用选择器 *

2.包含选择器

        2.1 子选择器 >

        2.2 后代选择器, 空格

        2.3 交集选择器,选择1.选择器

        2.4并集选择器,选择1,选择2

        2.5兄弟选择器,+

3.伪类选择器

        3.1 :hover

        3.2:focus

        3.3:before

        3.4:after

4.伪元素选择器

5.属性选择器

        这种选择器需要使用 [ ]

        5.1全匹配 [属性 =‘值’ ]

        5.2以什么开头 [属性名^=‘值’]

        5.3以什么结尾 [属性名$=‘值’]

        5.4包含某个值 [属性名*='' ]

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <title>jQuery选择器</title>

</head>

<body>

<div id="msg">这个是一个div</div>

<ul class="list">

    <li class="first">

        <ul>

            <li>这个是孙子列表1</li>

            <li>这个是孙子列表2</li>

            <li>这个是孙子列表3</li>

            <li>这个是孙子列表4</li>

            <li>这个是孙子列表5</li>

        </ul>

    </li>

    <li class="item">这个是一个列表</li>

    <li class="item">这个是一个列表</li>

    <li class="item active">这个是一个列表</li>

    <li class="item">这个是一个列表</li>

    <li class="item"></li>

    <div id="msg">这个是一个div</div>

    <ul>

        <li class="item"></li>

        <li class="item">这个是一个列表</li>

        <li class="item">这个是一个列表</li>

    </ul>

</ul>

<div class="show box">

</div>

<input type="tel" name="" id="" value="" />

<script src="js/jQuery-3.7.1.js"></script>

<script>

$(function () {

    // 1. id选择器

    //document.querySelector('#msg').style.color = 'blue'

    $('#msg').css('color', 'red')

    // 2. 类选择器

    $('.first').css('background', 'yellow')

    // 3. 标签选择器

    $('li').css('color', 'green')

    // 4. 属性选择器

    $('li[class*="active"]').css('color', 'red')

    // 5. 伪类选择器

    $('input').focus(function (){

        console.log(this)

        this.style.border = '1px solid blue'

    }).blur(function () {

        this.style.border = '1px solid red'

    })

})

</script>

</body>

</html>

jQuery

jQuery 官网地址:http://www.jquery.com

jQuery 动画

系统动画

在 jQuery 中提供了强大的动画 API 的支持,包括十种动画效果。

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <title>jQuery动画</title>

    <style>

        .box {

            width: 150px;

            height: 150px;

            background: #8B0000;

        }

    </style>

</head>

<body>

<div class="box"></div>

<button>点击隐藏</button>

<button>点击显示</button>

<button>点击透明</button>

<button>透明还原</button>

<button>滑动隐藏</button>

<button>滑动显示</button>

<button>点击淡出</button>

<button>点击淡入</button>

<script src="js/jQuery-3.7.1.js"></script>

<script>

    $(function () {

        // 1. 点击隐藏

        $("button:first").click(function () {

            $('.box').hide(1000)

        })

        // 2. 点击显示

        $('button:nth-child(3)').click(function () {

            $('.box').show(1000)

        })

        // 3. 点击透明

        $('button:nth-child(4)').click(function (){

            $('.box').fadeTo('slow', 0, function (){

                console.log('完全透明了')

            })

        })

        // 4. 透明还原

        $('button:nth-child(5)').click(function (){

            $('.box').fadeTo('slow', 1)

        })

        // 5. 滑动隐藏

        $('button:nth-child(6)').click(function (){

            $('.box').slideUp({

                duration: 500,

                easing: 'swing'

            })

        })

        // 6. 滑动显赫

        $('button:nth-child(7)').click(function (){

            $('.box').slideDown({

                duration: 500,

                easing: 'swing'

            })

        })

        // 7. 点击淡出

        $('button:nth-child(8)').click(function (){

            $('.box').fadeOut(1000)

        })

        // 8. 点击淡入

        $('button:nth-child(9)').click(function (){

            $('.box').fadeIn(1000)

        })

    })

</script>

</body>

</html>

自定义动画

如果系统动画不能满足外面的要求,那么外面就可以使用jQuery给我们提供的自定义动画,这种方式可以设置各种需要的动画效果。

要实现自定义动画,我们需要使用animate

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <title>jQuery自定义动画</title>

    <style>

        .box {

            width: 250px;

            height: 150px;

            /*border: 1px solid #243A64;*/

            border-radius: 10px;

            overflow: hidden;

            position: relative;

        }

        .box img {

            width: 250px;

            height: 150px;

            position: absolute;

        }

    </style>

</head>

<body>

<div class="box">

    <img src="images/1.jpg" class="first">

    <img src="images/2.jpg" class="last">

</div>

<button>点击动画开始</button>

<script src="js/jQuery-3.7.1.js"></script>

<script src="js/jquery.easing.1.3.js"></script>

<script>

    $(function () {

        $('button').click(function () {

            $('.box').animate({

                'width': '50px',

                'height': 0,

                'top': '100px',

                'left': '100px'

            }, {

                duration: 1000,

                easing: 'easeInOutQuint'

            })

        })

    })

    /*

    easing常见的值如下:

linear

swing

easeInQuad

easeOutQuad

easeInOutQuad

easeInCubic

easeOutCubic

easeInOutCubic

easeInQuart

easeOutQuart

easeInOutQuart

easeInQuint

easeOutQuint

easeInOutQuint

easeInExpo

easeOutExpo

easeInOutExpo

easeInSine

easeOutSine

easeInOutSine

easeInCirc

easeOutCirc

easeInOutCirc

easeInElastic

easeOutElastic

easeInOutElastic

easeInBack

easeOutBack

easeInOutBack

easeInBounce

easeOutBounce

easeInOutBounce

     */

</script>

</body>

</html>

常见API操作

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <title>常见API操作</title>

</head>

<body>

<div class="container">

    <ul class="list">

        <li>这个是列表1</li>

        <li>这个是列表2</li>

        <li>这个是列表3</li>

        <li class="active">这个是列表4

            <div>这个是一个子标签</div>

        </li>

        <li>这个是列表5</li>

        <li>这个是列表6</li>

        <li>这个是列表7</li>

        <li>这个是列表8</li>

        <li>这个是列表9</li>

        <li>这个是列表10</li>

    </ul>

</div>

<input type="text" name="usrname" id="usrname" value="123456" />

<script src="js/jquery-3.7.1.min.js"></script>

<script>

    $(function (){

        $('li:first').css('color', 'red')

        // 获取 ul li 的个数

        console.log($('.list').children('li').length)

        // 获取 ul 的第三个 li

        console.log($('.list').children().get(2))

        // 获取 带有 active li的内容

        console.log($('.active').html())

        // 修改 带有 active li的内容

        $('.active').html('<h3>这是修改后的</h3>')

        // 也可以用 text() 方法来获取

        console.log($('.active').text());

        // 获取文本框的值

        console.log($('#usrname').val())

        // 给文本框设置值

        $('input').val(3456)

        // 通过属性选择器获取

        $('input[name="usrname"]').val(789)

        // 遍历所有的li

        //console.log($('li').length);

        // 语法:each( function(index, Element) )

        // DOM 对象转换为 jQuery 对象:$(DOM对象)

        // jQuery 对象转换为 DOM 对象:let xx = $(对象)

        $('li').each(function (index, element) {

            console.log(index + '. ' + $(element).html())

        })

    })

</script>

</body>

</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/807913.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

头歌-机器学习 第9次实验 随机森林

第1关&#xff1a;Bagging 任务描述 本关任务&#xff1a;补充 python 代码&#xff0c;完成 BaggingClassifier 类中的 fit 和 predict 函数。请不要修改 Begin-End 段之外的代码。 相关知识 为了完成本关任务&#xff0c;你需要掌握&#xff1a; 什么是 Bagging&#xf…

李廉洋;4.11#黄金,WTI原油#行情走势分析策略。

美国银行预计&#xff0c;在今天召开的欧洲央行会议上不会有重大的政策变化&#xff0c;但欧洲央行正逐渐接近开始降息&#xff0c;尽管它采取的是一种谨慎的、依赖数据的方式。虽然欧洲央行对降息轨迹的信心不断增强&#xff0c;但降息的具体速度和幅度仍未公布&#xff0c;而…

QT系列教程(2) 创建项目和编译

新建Qt Widgets应用 我们启动qt creator 创建项目&#xff0c;选择Qt Widgets应用 接下来选择项目目录&#xff0c;项目名字就叫helloworld 构建系统选择qmake 我们创建一个名字为HelloDialog的类&#xff0c;继承于QDialog 构建套件选择你们安装的就行了&#xff0c;我这里选…

ELK及ELFK排错

目录 一、ELK及ELFK排错思路 1.1filebeat侧排查 1.2logstash侧排查 1.3ES、kibana侧问题 一、ELK及ELFK排错思路 1.1filebeat侧排查 第一步&#xff1a;排查filebeat上的配置文件有没有写错&#xff0c;filebeat的配置文件是yml文件&#xff0c;一定要注意格式。 第二步…

python botos s3 aws

https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/s3.html AWS是亚马逊的云服务&#xff0c;其提供了非常丰富的套件&#xff0c;以及支持多种语言的SDK/API。本文针对其S3云储存服务的Python SDK&#xff08;boto3&#xff09;的使用进行介绍。 …

男生裤子怎么选?5条永远不会出错的长裤分享

作为一名热衷于分享日常穿搭的博主&#xff0c;我在后台收到了很多粉丝的询问&#xff0c;大家都休息知道哪个品牌的裤子质量更好&#xff0c;而且风格能够适合男生。而且我注意到很多粉丝习惯于在网红直播间下单&#xff0c;对裤子的品牌以及基本品质并不够了解&#xff0c;所…

suno有了新对手udio炸裂音乐圈;又一个开源AI Devin 程序员;完全开源轻量级的文本到语音可生成特定说话者的风格

✨ 1: udio 由音乐和科技界重量级人物支持的强大 AI 音乐生成器&#xff0c;被称为音乐界的另一个 ChatGPT。 Udio 由前 Google DeepMind的研究院和工程师创立&#xff0c;得到了a16z的支持&#xff0c;总部在伦敦和纽约。 目前是一个免费的V1测试版产品&#xff0c;每个人每…

缺失msvcr110.dll要怎么处理?快捷的修复msvcr110.dll方法

当你在使用电脑进行工作或娱乐时&#xff0c;可能会突然遇到一个错误提示&#xff1a;“程序无法启动&#xff0c;因为电脑中缺失msvcr110.dll”。这样的情况不仅会打断你的活动&#xff0c;还可能带来一定程度的不便。面对这个在Windows操作系统中相对常见的问题&#xff0c;其…

在隐私计算应用中和数链具备哪些技术特点?

在加速“可信数字化”进程的背景下&#xff0c;我国区块链产业将在打造新型平台经济&#xff0c;开启共享经济新时代的同时&#xff0c;带动数字经济“脱虚向实”服务实体经济。 和数软件在加速数字化进程的同时&#xff0c;进一步服务实体经济&#xff0c;提高实体经济的活力…

抖音IP打造品牌规划流量运营方案推广计划书

【干货资料持续更新&#xff0c;以防走丢】 抖音IP打造品牌规划流量运营方案推广计划书 部分资料预览 资料部分是网络整理&#xff0c;仅供学习参考。 50页可编辑&#xff08;完整资料包含以下内容&#xff09; 目录 详细的抖音运营方案&#xff0c;帮助品牌在抖音平台上提升…

如何切换PHP版本

如果服务器上安装了多个php&#xff0c;可能会导致默认的php版本错误&#xff0c;无法启动swoole等服务&#xff0c; 查看命令行的php版本方法&#xff1a;https://q.crmeb.com/thread/9921 解决方法如下&#xff0c;选一个即可&#xff1a; 一、切换命令行php版本&#xff0c…

3d怎么按路径制作模型---模大狮模型网

在3D建模中&#xff0c;按路径制作模型是一种常见的技术&#xff0c;特别适用于创建曲线、管道、绳索等线性形状的物体。虽然这项技术可能对初学者来说有些复杂&#xff0c;但通过一步步的指导和实践&#xff0c;你将能够掌握它。本文将详细介绍按路径制作模型的步骤&#xff0…

宁盾radius认证服务器软件如何实现802.1X认证/Portal认证上网(portal web入网认证)

一、什么是802.1X认证和Portal认证以及有什么区别 随着企业网络规模的不断扩大和网络安全威胁的日益加剧&#xff0c;有效的网络认证机制成为保障网络安全的关键。其中&#xff0c;802.1X认证和Portal认证是两种常见的网络认证方式&#xff0c;它们各有特点&#xff0c;适用于…

手动实现简易版RPC(下)

手动实现简易版RPC(下) 前言 什么是RPC&#xff1f;它的原理是什么&#xff1f;它有什么特点&#xff1f;如果让你实现一个RPC框架&#xff0c;你会如何是实现&#xff1f;带着这些问题&#xff0c;开始今天的学习。 接上一篇博客 手动实现简易版RPC&#xff08;上&#xff…

【git】为什么git要有 暂存区

关于git暂存区的个人理解 暂存区 一般存放在 .git 目录下的 index 文件&#xff08;.git/index&#xff09;中。 git中的修改需要先add到暂存区&#xff0c;再commit到本地库&#xff0c;乍一看好像是多此一举了。 看了些别人的讨论&#xff0c;自己也想了很久&#xff0c;…

二叉树应用——最优二叉树(Huffman树)、贪心算法—— Huffman编码

1、外部带权外部路径长度、Huffman树 从图中可以看出&#xff0c;深度越浅的叶子结点权重越大&#xff0c;深度越深的叶子结点权重越小的话&#xff0c;得出的带权外部路径长度越小。 Huffman树就是使得外部带权路径最小的二叉树 2、如何构造Huffman树 &#xff08;1&#xf…

【每日刷题】Day10

【每日刷题】Day10 &#x1f955;个人主页&#xff1a;开敲&#x1f349; &#x1f525;所属专栏&#xff1a;每日刷题&#x1f345; 目录 1. 环形链表的约瑟夫问题_牛客题霸_牛客网 (nowcoder.com) 2. 21. 合并两个有序链表 - 力扣&#xff08;LeetCode&#xff09; 3. 152…

灌醉阿里P8大佬!获取内部二进制网络安全学习路线(建议收藏

0x01 二进制学习路线 1.踏实的基础。 基础是很重要的&#xff0c;可以通过计算机体系结构来学习&#xff0c;当然肯定不只是计算机体系结构&#xff0c;还有很多的知识。计算机科学系统基础知识的积累和沉淀&#xff0c;提升自己的计算机科学素养&#xff0c;理解计算机的工作…

windows中anaconda下创建新的新的jupyter环境

https://blog.csdn.net/weixin_43491496/article/details/130325001?spm1001.2014.3001.5502 这里写目录标题 1.1界面化创建虚拟环境1.2命令行创建虚拟环境2.查看是否创建成功3.激活虚拟环境pylessonppt4.更改工作目录5.删除6.查看是否删除成功 1.1界面化创建虚拟环境 1.2命令…

润乾报表平台 InputServlet 任意文件上传漏洞复现

0x01 产品简介 润乾报表是一个纯JAVA的企业级报表工具,支持对J2EE系统的嵌入式部署,无缝集成。服务器端支持各种常见的操作系统,支持各种常见的关系数据库和各类J2 EE的应用服务器,客户端采用标准纯html方式展现,支持ie和netscape, 润乾报表是领先的企业级报表分析软件。…