前端三剑客 —— 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>

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

一文读懂RISC-V与ARM

RISC-V和ARM是近年来备受关注的两种处理器架构。RISC-V是一种基于精简指令集计算(RISC)原理的开源指令集架构(ISA)&#xff0c;而ARM是一种专有ISA&#xff0c;由于其长期存在于嵌入式系统和移动设备中&#xff0c;已成为嵌入式系统和移动设备的主导选择。市场以及多年积累的信…

安装图数据库Nebula Graph

前言 今年开始&#xff0c;很多机关单位、央国企都要求所有新建的信息系统必须走国产化技术路线&#xff0c;而且还要求满足“信创”要求。“信创”通俗来讲就是要自研&#xff0c;那种拿个开源套壳的都不满足信创要求。之前研究了一段时间的neo4j&#xff0c;显然neo4j不满足…

雪亮工程视频联网综合管理/视频智能分析系统建设方案(一)

一、行业背景 雪亮工程主要是针对农村地区治安防控的监控项目&#xff0c;在乡村的主干道、路口、人群聚集地部署高清摄像头&#xff0c;通过三级综治中心和指挥平台&#xff0c;将视频图像信息系统纵向下延至县、乡、村&#xff0c;同时利用系统拓展在安防、社会治理、智慧交…

MWeb Pro For Mac v4.5.9 强大的 Markdown 软件中文版

MWeb 是专业的 Markdown 写作、记笔记、静态博客生成软件&#xff0c;目前已支持 Mac&#xff0c;iPad 和 iPhone。MWeb 有以下特色&#xff1a; 软件下载&#xff1a;MWeb Pro For Mac v4.5.9 软件本身&#xff1a; 使用原生的 macOS 技术打造&#xff0c;追求与系统的完美结合…

Linux从入门到精通 --- 3.用户、权限

文章目录 第三章&#xff1a;3.1 root用户3.1.1 su3.1.2 exit3.1.3 sudo 3.2 用户和用户组3.2.1 用户组管理创建用户组删除用户组 3.2.2 用户管理创建用户删除用户查看用户所属组修改用户所属组 3.2.3 getent一&#xff1a;二&#xff1a; 3.3 查看权限控制信息3.3.1 认知权限信…

IDEA 控制台中文乱码 4 种解决方案

前言 IntelliJ IDEA 如果不进行相关设置&#xff0c;可能会导致控制台中文乱码、配置文件中文乱码等问题&#xff0c;非常影响编码过程中进行问题追踪。本文总结了 IDEA 中常见的中文乱码解决方法&#xff0c;希望能够帮助到大家。 IDEA 中文乱码 解决方案 一、设置字体为支…

软件安全评估之设计评审入门(上)

壹 基础概念 在软件开发生命周期&#xff08;Software Development Life Cycle&#xff0c;简称SDLC&#xff09;中&#xff0c;设计评审&#xff08;Design Review&#xff09;是一个关键的阶段&#xff0c;旨在确保软件设计满足项目需求和目标&#xff0c;并且能够高效、可靠…

GDAL源码剖析(九)之GDAL体系架构

GDAL源码剖析&#xff08;九&#xff09;之GDAL体系架构_gdal 源码-CSDN博客 在GDAL库中包含栅格数据的读写&#xff0c;矢量数据的读写&#xff0c;以及栅格和矢量数据的相关算法。下面主要对GDAL中栅格数据和矢量数据的体系架构做一个简单的说明。本人英文很烂&#xff0c;有…

集装箱5G智能制造工厂数字孪生可视化平台,推进企业数字化转型

集装箱5G智能制造工厂数字孪生可视化平台&#xff0c;推进企业数字化转型。在当下数字化转型的热潮中&#xff0c;集装箱5G智能制造工厂数字孪生可视化平台成为了推动企业转型升级的重要工具。这一平台将先进的5G技术与智能制造相结合&#xff0c;通过数字孪生技术实现生产过程…

数字化赋能农业创新发展新篇章:数字乡村建设推动农业现代化、提升农业综合效益与竞争力

目录 一、数字乡村建设的内涵与意义 二、数字化赋能农业创新发展的路径 1、推动智慧农业发展 2、加强农村电子商务建设 3、提升农业信息化水平 三、数字乡村建设推动农业现代化与提升综合效益与竞争力 1、推动农业现代化进程 2、提升农业综合效益 3、增强农业竞争力 …

HTML5+CSS3+JS小实例:图片切换特效之模糊变清晰

实例:图片切换特效之模糊变清晰 技术栈:HTML+CSS+JS 效果: 源码: 【HTML】 <!DOCTYPE html> <html lang="zh-CN"> <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, i…

Windows搭建Jellyfin影音服务结合内网穿透实现公网访问本地视频文件

文章目录 1. 前言2. Jellyfin服务网站搭建2.1. Jellyfin下载和安装2.2. Jellyfin网页测试 3.本地网页发布3.1 cpolar的安装和注册3.2 Cpolar云端设置3.3 Cpolar本地设置 4.公网访问测试5. 结语 1. 前言 随着移动智能设备的普及&#xff0c;各种各样的使用需求也被开发出来&…

大势智慧在出模型时输入七参数可以导出地方坐标系吗?

大势智慧自主研发的网格大师或者DasViewer有坐标转换功能&#xff0c;可以使用七参数计算功能转换到地方坐标&#xff0c;直接输以前的七参是不行的&#xff0c;需要准备源坐标和目标坐标。 DasViewer是由大势智慧自主研发的免费的实景三维模型浏览器,采用多细节层次模型逐步自…

【Unity】组件组合使用心得(单行可自动拓展Scroll View)

在这之前&#xff0c;一直是在使用Scroll View进行滑动内容设置&#xff0c;但设置的都是不明不白的&#xff0c;而且有的时候设置好了之后也不知道是为什么&#xff0c;总感觉哪里不对劲&#xff0c;而且好也不知道为什么好&#xff0c;可能是长时间在做管理上的内容&#xff…

淘宝详情API接口文档(java)get调用

淘宝详情API接口是用于获取淘宝商品详细信息的接口&#xff0c;它允许开发者通过发送请求&#xff0c;获取商品的描述、价格、评价等信息。下面是一个关于淘宝详情API接口的示例文档&#xff0c;包括接口地址、请求参数、响应参数等内容。 淘宝详情API接口文档 一、接口地址 …

Lobe UI - 基于 AntDesign 开发的 AIGC Web 应用的开源 UI 组件库

今天推荐一个可以快速开发 ChatGPT UI 界面的组件库&#xff0c;质量很高&#xff0c;拿来就能用。 Lobe UI 是由 lobehub 团队开发的一套 web UI 组件库&#xff0c;和我之前推荐的很多通用型的 UI 组件库不同&#xff0c;Lobe UI 是专门为目前火热的 AIGC 应用开发而打造&am…

分布式 SpringCloudAlibaba、Feign与RabbitMQ实现MySQL到ES数据同步

文章目录 ⛄引言一、思路分析⛅实现方式⚡框架选择 二、实现数据同步⌚需求分析⏰搭建环境⚡核心源码 三、测试四、源码获取⛵小结 ⛄引言 本文参考黑马 分布式Elastic search Elasticsearch是一款非常强大的开源搜索引擎&#xff0c;具备非常多强大功能&#xff0c;可以帮助…

R语言绘制一次和二次相关性热图

在数据探索的过程中&#xff0c;我们往往会对数据与数据的相关性进行分析&#xff0c;例如我们常用的corrplot包&#xff0c;或者psych包中的corr.test函数&#xff0c;对两两变量间的相关性进行分析。我们常常会看到这样的相关性热图&#xff1a; 但有时变量间的关系并非线性…

在线课程平台LearnDash评测 – 最佳 WordPress LMS插件

在我的LearnDash评测中&#xff0c;我探索了流行的 WordPress LMS 插件&#xff0c;该插件以其用户友好的拖放课程构建器而闻名。我深入研究了各种功能&#xff0c;包括课程创建、测验、作业、滴灌内容、焦点模式、报告、分析和管理工具。 我的评测还讨论了套餐和定价选项&…

Linux基础指令补全,权限问题分析—3

一、命令补全&#xff1a; 1.bc指令&#xff1a; 功能&#xff1a;命令行计算器&#xff0c;使用quit退出语法&#xff1a;bc 算式 2.uname指令&#xff1a; 语法&#xff1a;uname 选项功能&#xff1a;uname原来获取电脑或操作系统的相关信息选项&#xff1a; ①-a选项&am…