zoukankan      html  css  js  c++  java
  • day49 前端之 jQery

    JQuery

    介绍

    jQuery是一个快速、简洁的JavaScript框架,是继Prototype之后又一个优秀的JavaScript代码库(或JavaScript框架)。jQuery设计的宗旨是“write Less,Do More”,即倡导写更少的代码,做更多的事情。它封装JavaScript常用的功能代码,提供一种简便的JavaScript设计模式,优化HTML文档操作、事件处理、动画设计和Ajax交互。

    jQuery的核心特性可以总结为:具有独特的链式语法和短小清晰的多功能接口;具有高效灵活的css选择器,并且可对CSS选择器进行扩展;拥有便捷的插件扩展机制和丰富的插件。jQuery兼容各种主流浏览器,如IE 6.0+、FF 1.5+、Safari 2.0+、Opera 9.0+等

    jQuery就类似于python的模块,帮你封装了一对复杂的操作暴露给你一些简易的接口

    前端的模块 叫'类库'

    JQuery对象

    JQuery库中,可以通过本身自带的方法获取页面DOM 元素的对象叫做JQuery对象。对象用var开头定义。

    $("#d1").html()的意思是:获取id值为  d1的元素的html代码。其中 html()是jQuery里的方法。

    相当于: document.getElementById("d1").innerHTML;

    虽然 jQuery对象是包装 DOM对象后产生的,但是 jQuery对象无法使用 DOM对象的任何方法,同理 DOM对象也没不能使用 jQuery里的方法。

    在声明一个jQuery对象变量的时候在变量名前面加上$:

    var $variable = jQuery对像
    var variable = DOM对象
    $variable[0]//jQuery对象转成DOM对象

    使用:

    $("#i1").html();//jQuery对象可以使用jQuery的方法
    $("#i1")[0].innerHTML;// DOM对象使用DOM的方法

    JQuery的基本语法结构

    $(选择器).action(属性)

    例子:将111111先用原生的js语法把颜色变成红色,再用jquery将他变成蓝色

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>Title</title>
    
    <script src="jQuery-3.4.1.js"></script>
    </head>
    <body>
    <p>111111</p>
    </body>
    </html>
    View Code

    ..

     

    基本选择器

    标签选择器
    $('tagname')
    id选择器
    $('#id')
    class选择器
    $('.className')
    配合使用
    $('div.c1')
    所有元素选择器
    $('*')
    组合选择器
    $('#id, .className, tagName')
    层级选择器

    x和y可以为任意选择器

    $("x y");// x的所有后代y(子子孙孙)
    $("x > y");// x的所有儿子y(儿子)
    $("x + y")// 找到所有紧挨在x后面的y
    $("x ~ y")// x之后所有的兄弟y
    基本筛选器
    :first // 第一个
    :last // 最后一个
    :eq(index)// 索引等于index的那个元素
    :even // 匹配所有索引值为偶数的元素,从 0 开始计数
    :odd // 匹配所有索引值为奇数的元素,从 0 开始计数
    :gt(index)// 匹配所有大于给定索引值的元素
    :lt(index)// 匹配所有小于给定索引值的元素
    :not(元素选择器)// 移除所有满足not条件的标签
    :has(元素选择器)// 选取所有包含一个或多个标签在其内的标签(指的是从后代元素找)

    例子:

    $("div:has(h1)")// 找到所有后代中有h1标签的div标签
    $("div:has(.c1)")// 找到所有后代中有c1样式类的div标签
    $("li:not(.c1)")// 找到所有不包含c1样式类的li标签
    $("li:not(:has(a))")// 找到所有后代中不含a标签的li标签

     

    练习:模态框,使用jQuery实现弹出和隐藏功能

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>Title</title>
        <script src="jQuery-3.4.1.js"></script>
        <style>
            .cover {
                position:fixed ;
                top: 0;
                left: 0;
                bottom: 0;
                right: 0;
                background-color: darkgray;
                z-index: 9;
            }
            .model {
                /*固定*/
                position: fixed;
                top: 50%;
                left: 50%;
                height: 200px;
                width: 400px;
                background-color: darkgray;
                /**/
                z-index: 10;
                margin-top: -100px;
                margin-left: -200px;
            }
    
            .hidden {
                display:none ;
            }
    
    
    
        </style>
    
    </head>
    <body>
    <div class="c1"> 我是最下面的</div>
    
    <button class="c2">按钮</button>
    <div class="cover hidden"></div>
    <div class="model hidden">
    
        <p> username:<input type="text"></p>
        <p> password:<input type="text"></p>
        <button class="cancel">取消</button>
    </div>
    <script>
        var c1Ele = $('.c2')[0];
        c1Ele.onclick = function () {
        //    将中间和白框的hidden 类属性移除
            $('.cover').removeClass('hidden');
            $('.model').removeClass('hidden')
        };
        var cancelEle = $('.cancel')[0];
        cancelEle.onclick = function () {
        //    添加
            $('.cover').addClass('hidden');
            $('.model').addClass('hidden')
        }
    
    </script>
    </body>
    </html>
    模态框

    属性选择器

    [attribute]
    [attribute=value]// 属性等于
    [attribute!=value]// 属性不等于

    代码:

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>Title</title>
        <script src="jQuery-3.4.1.js"></script>
    </head>
    <body>
    <div class="c1">div</div>
    <p username="user">p</p>
    <span class="c1">span</span>
    </body>
    </html>
    View Code

    表单筛选器

    :text
    :password
    :file
    :radio
    :checkbox
    
    :submit
    :reset
    :button

    代码

    从bootcdn中引用script链接,或者从本地拷一个

    压缩链接:<script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>Title</title>
        <!--引用jQuery-->
        <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
    </head>
    <body>
    <!--参数:action 控制from表单信息的提交位置,不写默认当前地址-->
    <!--method 默认为get-->
    <!--enctype 默认为application/x-www-form-urlencoded 传普通键值
    改为multipart/form-data 传文件 -->
    <!--novalidate 告诉浏览器不要做额外的校验-->
    <form action="" >
        <p><label for="d1">username:<input type="text" id="d1"></label></p>
        <p><label for="d2">password:<input type="text" id="d2"></label></p>
        <input type="submit">
        <br>
        <!--单选-->
        <select name="" id="">
            <option value="" selected>1111</option>
            <option value="">2222</option>
            <option value="">3333</option>
        </select>
        <br>
        <!--复选-->
        <input type="checkbox" name="like" checked><input type="checkbox" name="like"><input type="checkbox" name="like" checked><input type="checkbox" name="like"></form>
    
    </body>
    </html>
    View Code

     

     表单对象属性

    :enabled
    :disabled
    :checked
    :selected

    例子:

     

    <select id="s1">
      <option value="beijing">北京市</option>
      <option value="shanghai">上海市</option>
      <option selected value="guangzhou">广州市</option>
      <option value="shenzhen">深圳市</option>
    </select>
    
    $(":selected")  // 找到所有被选中的option

    筛选器方法

    代码

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
    </head>
    <body>
    <span>span1</span>
    <span>span2</span>
    <div id="d1">div
        <span>div>span</span>
        <p class="c1">div>p
            <span class="c2">div>p>span</span>
        </p>
        <span id="d2">div>span</span>
    </div>
    <span>span1</span>
    <span>span2</span>
    <span id="d3"></span>
    </body>
    </html>
    View Code

    下一个元素:

    $("#id").next()
    $("#id").nextAll()
    $("#id").nextUntil("#i2")

    上一个元素:

    $("#id").prev()
    $("#id").prevAll()
    $("#id").prevUntil("#i2")

    父亲元素:

    $("#id").parent()
    $("#id").parents()  // 查找当前元素的所有的父辈元素
    $("#id").parentsUntil() // 查找当前元素的所有的父辈元素,直到遇到匹配的那个元素为止

    儿子和兄弟元素:

    $("#id").children();// 儿子们
    $("#id").siblings();// 兄弟们

    注意:对象与对象的转换

    查找

    搜索所有与指定表达式匹配的元素。这个函数是找出正在处理的元素的后代元素的好方法。

    $("div").find("p")

    等价于$("div p")

    筛选

    筛选出与指定表达式匹配的元素集合。这个方法用于缩小匹配的范围。用逗号分隔多个表达式。

    $("div").filter(".c1")  // 从结果集中过滤出有c1样式类的

    等价于 $("div.c1")

    补充

    .first() // 获取匹配的第一个元素
    .last() // 获取匹配的最后一个元素
    .not() // 从匹配元素的集合中删除与指定表达式匹配的元素
    .has() // 保留包含特定后代的元素,去掉那些不含有指定后代的元素。
    .eq() // 索引值等于指定值的元素

    练习:左侧菜单

  • 相关阅读:
    slf4j使用
    centos 安装 redis
    centos安装单机zookeeper
    activemq消息重发机制[转]
    maven 指定工程的 jdk 版本及编译级别
    Elasticsearch-索引新数据(创建索引、添加数据)
    Elasticsearch-数据的存储、搜索(干货)
    Yarn-本地获取任务日志
    Hive-Container killed by YARN for exceeding memory limits. 9.2 GB of 9 GB physical memory used. Consider boosting spark.yarn.executor.memoryOverhead.
    Elasticsearch-安装、日志解读
  • 原文地址:https://www.cnblogs.com/komorebi/p/11499438.html
Copyright © 2011-2022 走看看