首页 > 其他分享 >jQuery语法

jQuery语法

时间:2024-03-24 17:11:06浏览次数:23  
标签:jQuery function hide 标签 元素 语法 id 属性

【一】查找标签

【1】基本选择器

// id选择器
$('#id')

// 标签选择器
$('tag')

// 类选择器
$('.class')

// 找到由xx类的xx标签
$('tag.class')

// 所有元素选择器
$('*')

// 组合选择器
$("#id, .className, tagName")

【2】层级选择器

// x,y 这里指代任意标签

// x的所有后代y(子子孙孙)
$('x y')

// x的所有儿子y
$('s > y')

// 所有紧跟在x后面的y
$('x + y')

// x之后所有的兄弟y
$('x ~ y')

【3】基本筛选器

// 第一个
:first

// 最后一个
:last

// 索引等于index的那个元素
:eq(index)

// 配所有索引值为偶数的元素,从 0 开始计数
:even

// 匹配所有索引值为奇数的元素,从 0 开始计数
:odd

// 匹配所有大于给定索引值的元素
:gt(index)

// 匹配所有小于给定索引值的元素
:lt(index)

// 移除所有满足not条件的标签
:not(元素选择器)

// 选取所有包含一个或多个标签在其内的标签(指的是从后代元素找)
:has(元素选择器)

例子

// 找到所有后代中有h1标签的div标签
$("div:has(h1)")

// 找到所有后代中有c1样式类的div标签
$("div:has(.c1)")

// 找到所有不包含c1样式类的li标签
$("li:not(.c1)")

// 找到所有后代中不含a标签的li标签
$("li:not(:has(a))")

练习

  • 自定义模态框
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="jQuery.min.js"></script>

    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script>
    <script></script>
    <style>
        .cover{
            position: fixed;
            top: 0;
            left: 0;
            bottom: 0;
            right: 0;
            background-color: rgba(128,128,128,0.4);
            z-index: 99;
        }
        .modal {
            position: fixed;
            height: 400px;
            width: 600px;
            background-color: white;
            top: 50%;
            left: 50%;
            margin-left: -300px;
            margin-top: -200px;
            z-index: 1000;
        }
        .hide {
            display: none;
        }
    </style>
</head>
<body>
<div id="d3">我是最下面的</div>
<button id="d1">登录</button>
<div class="cover hide"></div>
<div class="modal hide" id="d4">
    <p>username:<input type="text"></p>
    <p>password:<input type="text"></p>
    <input type="button" value="确认">
    <input type="button" value="取消" id="d2">
</div>
<script>
    let $coverEle = $('div.cover')
    let $modaEle = $('#d4')
    let $cancelEle = $('')
    $('#d1').on('click',function (){
        // 将俩个hide类属性移除
        $coverEle.removeClass('hide')
        $modaEle.removeClass('hide')
    })
    $('#d2').on('click',function (){
    // 将俩个hide类属性移除
    $coverEle.addClass('hide')
    $modaEle.addClass('hide')
    })
</script>
</body>
</html>

【4】属性选择器

// 取所有有a属性的标签
$('[a]')

// 取所有a属性是b的标签
$('[a=b]')

// 取所有a属性不是b的标签
$('[a!=b]')

例子

// 示例
<input type="text">
<input type="password">
<input type="checkbox">
    
// 取到checkbox类型的input标签
$("input[type='checkbox']");

// 取到类型不是text的input标签
$("input[type!='text']");

【5】表单选择器

// 获取所有文本输入框元素
$(':text')

// 获取所有密码输入框元素
$(':password')

// 获取所有文件上传输入框元素
$(':file')

// 获取所有单选输入框元素
$(':radio')

// 获取所有复选框元素
$(':checkbox')

// 选取所有提交按钮元素
$(':submit')

// 选取所有重置按钮元素
$(':reset')

// 选取所有按钮元素
$(':button')

【6】表单对象属性

// 选取所有可用的表单元素。
$("input:enabled")

// 选择所有被禁用的输入框
$("input:disabled")

//选取所有被选中的复选框或单选按钮
$("input:checked")

//选取所有被选中的下拉列表选项
$("select option:selected")

例子

// 找到可用的input标签

<form>
  <input name="email" disabled="disabled" />
  <input name="id" />
</form>

$("input:enabled")  // 找到可用的input标签
// 找到被选中的option:

<select id="s1">
  <option value="beijing">北京市</option>
  <option value="shanghai">上海市</option>
  <option selected value="guangzhou">广州市</option>
  <option value="shenzhen">深圳市</option>
</select>

$(":selected")  // 找到所有被选中的option

【7】筛选器方法

// 下一个元素
$('#id').next()

// 下面所有的元素
$('#id').nextAll()

// 下面直到某个标签之间所有的元素
$('#id')nextUntil('#id2')

// 上一个元素
$('#id').prev()

// 上面所有的元素
$('#id').prevAll()

// 上面直到某个标签之间所有的元素
$('#id').prevUntil('#id2')

// 父亲元素
$('#id').parent()

// 所有父亲元素
$('#id').parentAll()

// 直到某个标签之间的所有父亲元素
$('#id').parentUntil('#id2')

// 儿子元素
$('#id').children()

// 兄弟元素
$("#id").siblings()

// 搜索所有与指定表达式匹配的元素。这个函数是找出正在处理的元素的后代元素的好方法。
$("div").find("p") == $('div p')

// 筛选出与指定表达式匹配的元素集合。这个方法用于缩小匹配的范围。用逗号分隔多个表达式。
$('div').filter('.c1') == $('div.c1')

补充

// 获取匹配的第一个元素
.first()

// 获取匹配的最后一个元素
.last()

// 从匹配元素的集合中删除与指定表达式匹配的元素
.not() 

// 保留包含特定后代的元素,去掉那些不含有指定后代的元素。
.has() 

// 索引值等于指定值的元素
.eq() 

案例

// 左侧下拉栏案例
// 要求点击哪个标签 哪个标签就展开内容,其他标签隐藏内容

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="jQuery.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/js/bootstrap.min.js"></script>
    <style>
        .left {
            float: left;
            background-color: pink;
            width: 20%;
            height: 100%;
            position: fixed;
        }
        .title {
            font-size: 24px;
            color: white;
            text-align: center;
        }
        .item {
            border: 1px solid black;
        }
        .hide {
            display: none;
        }
    </style>
</head>
<body>
<div class="left">
    <div class="menu">
        <div class="title">菜单一
            <div class="item">111</div>
            <div class="item">222</div>
            <div class="item">333</div>
        </div>
    </div>
    <div class="menu">
        <div class="title">菜单二
            <div class="item">111</div>
            <div class="item">222</div>
            <div class="item">333</div>
        </div>
    </div>
    <div class="menu">
        <div class="title">菜单三
            <div class="item">111</div>
            <div class="item">222</div>
            <div class="item">333</div>
        </div>
    </div>
</div>
<script>
    $('.title').on('click',function (){
        // 给所有的item加hide
        $('.item').addClass('hide')
        // 再给当前点击对象的子元素全部取消hide
        $(this).children().removeClass('hide')
    })
</script>
</body>
</html>

【二】操作标签

【1】样式操作

// 添加指定CSS类名
$('#id').addClass('class')

// 删除指定CSS类名
$('#id').removeClass('class')

// 判断指定CSS类名是否存在
$('#id').hasClass('class')

// 切换指定CSS类名,如果有就移除,没有就添加
$('#id').toggleClass('class')

案例

// 开关灯案例
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="jQuery.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script>
    <style>
        #d1 {
            width: 300px;
            height: 300px;
            border-radius: 50%;
        }

        .bg_green {
            background-color: green;
        }

        .bg_red {
            background-color: red;
        }
    </style>
</head>
<body>
<div class="bg_green bg_red" id="d1"></div>
<button id="d2">开灯</button>
<script>
    let divEle = $('#d1')
    let btnEle = $('#d2')
    btnEle.click(function (){
        divEle.toggleClass('bg_red')
    })
</script>
</body>
</html>
// 模态框案例
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="jQuery.min.js"></script>

    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script>
    <script></script>
    <style>
        .cover{
            position: fixed;
            top: 0;
            left: 0;
            bottom: 0;
            right: 0;
            background-color: rgba(128,128,128,0.4);
            z-index: 99;
        }
        .modal {
            position: fixed;
            height: 400px;
            width: 600px;
            background-color: white;
            top: 50%;
            left: 50%;
            margin-left: -300px;
            margin-top: -200px;
            z-index: 1000;
        }
        .hide {
            display: none;
        }
    </style>
</head>
<body>
<div id="d3">我是最下面的</div>
<button id="d1">登录</button>
<div class="cover hide"></div>
<div class="modal hide" id="d4">
    <p>username:<input type="text"></p>
    <p>password:<input type="text"></p>
    <input type="button" value="确认">
    <input type="button" value="取消" id="d2">
</div>
<script>
    let $coverEle = $('div.cover')
    let $modaEle = $('#d4')
    let $cancelEle = $('')
    $('#d1').on('click',function (){
        // 将俩个hide类属性移除
        $coverEle.removeClass('hide')
        $modaEle.removeClass('hide')
    })
    $('#d2').on('click',function (){
    // 将俩个hide类属性移除
    $coverEle.addClass('hide')
    $modaEle.addClass('hide')
    })
</script>
</body>
</html>

【2】位置操作

// 获取匹配元素在当前窗口的相对偏移或设置元素位置
offset()

// 获取匹配元素相对父元素的偏移
position()

// 获取匹配元素相对滚动条顶部的偏移
scrollTop()

// 获取匹配元素相对滚动条左侧的偏移
scrollLeft()

案例

// 返回顶部案例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="jQuery.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/js/bootstrap.min.js"></script>
  <style>
    .hide {
      display: none;
    }

    #d1 {
      position: fixed;
      background-color: blue;
      right: 20px;
      bottom: 20px;
      height: 50px;
      width: 50px;
    }
  </style>
</head>
<body>
<a href="" id="d1"></a>
<div style="height: 500px;background-color: red"></div>
<div style="height: 500px;background-color: pink"></div>
<div style="height: 500px;background-color: yellowgreen"></div>
<a href="#d1" class="hide">回到顶部</a>
<script>
  $(window).scroll(function (){
    if($(window).scrollTop()>300){
      $('#d1').removeClass('hide')
    }else {
      $('#d1').addClass('hide')
    }
  })
</script>
</body>
</html>

【3】获取尺寸

height()
width()
innerHeight()
innerWidth()
outerHeight()
outerWidth()

【4】文本操作

// 获取html内容
html()

// 设置html内容
html('val')

// 获取文本内容
text()

// 设置文本内容
text('val')

// 获取值内容
val()

// 设置值内容
val('val')

// 设置多选的checkbox、多选select的值
val([val1, val2])

例子

<input type="checkbox" value="basketball" name="hobby">篮球
<input type="checkbox" value="football" name="hobby">足球

<select multiple id="s1">
    <option value="1">1</option>
    <option value="2">2</option>
    <option value="3">3</option>
</select>

// 设置属性name=hobby 的标签值
$("[name='hobby']").val(['basketball', 'football']);

【5】属性操作

// 返回对应标签元素的指定属性的属性值
$('#id').attr('attrName')

// 设置对应标签元素的属性值
$('#id').attr('attrName','attrValue')

// 设置对应标签元素的多个属性值
$('#id').attr({k1: v1, k2:v2})

// 删除对应标签元素的指定属性
$('#id').removeAttr('attrName')

用于checkbox和radio

// 获取属性
prop()

// 移除属性
removeProp()

prop和attr的区别

  • prop和attr两者都是属性的意思,但是两者分别指向的属性不同
  • attr指向的属性是html标签的属性
  • prop指向的属性是DOM对象属性

例子

<input type="checkbox" id="i1" value="1">
    
$("#i1").attr("checked")  // undefined
$("#i1").prop("checked")  // false

// 对于html标签里面没有的属性,使用attr会得到undefined
// 而对于prop会得到false
<input type="checkbox" checked id="i1" value="1">
    
$("#i1").attr("checked")   // checked
$("#i1").prop("checked")  // true

// 这样就可以看出来attr的局限性,它的作用只限于HTML标签内的属性
// 而prop获取的是DOM对象属性,他会检索这个对象是否有这个属性,有这个属性就返回true反之则是false

总结

  • 对于标签上有的能看到的属性和自定义属性都用attr
  • 对于返回布尔值的比如checkbox、radio和option的是否被选中都用prop。

【三】事件

【1】常用事件

// 点击事件
click(function(){...})

// 悬停事件
hover(function(){...})

// 失焦事件
blur(function(){...})

// 聚焦事件
focus(function(){...})

// 改变事件
change(function(){...})

// 键盘抬起事件
keyup(function(){...})

案例

// hover事件

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="jQuery.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/js/bootstrap.min.js"></script>
</head>
<body>
<p id="d1">励志成为python大牛</p>
<script>
    $('#d1').hover(function () {
            alert('沉淀')
        },
        function () {
            alert('继续沉淀')
        })
</script>
</body>
</html>
// input实时监控

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="jQuery.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/js/bootstrap.min.js"></script>
</head>
<body>
<input type="text" id="d1">
<script>
  $('#d1').on('input',function (){
    console.log($(this).val())
  })
</script>
</body>
</html>

【2】事件绑定

// 方式1
$('#id').events(function(){})

// 方式2
$('#id').on('events',function(){})

【3】移除事件

$('#id').off('events',function(){})

【4】阻止后续事件执行

// 方式1
在函数体最后 加上 return false

// 方式2
给函数加上一个形参 e
在函数体最后加上 e.preventDefault()

【5】阻止事件冒泡

  • 事件冒泡是指当一个特定的事件发生在 DOM 树上的某个元素上时,这个事件将会从那个元素开始,然后逐级向上传播到 DOM 树的根节点。换句话说,如果一个元素具有某个事件的处理程序,当该事件在该元素上触发时,它将会先执行该元素的事件处理程序,然后再向该元素的父级元素传播,直到传播到整个文档的根节点。

  • 如果想要阻止事件冒泡

  • 直接在函数体最后加上return false

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="jQuery.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/js/bootstrap.min.js"></script>
</head>
<body>
<div>div
    <p>p
        <span>span</span>
    </p>
</div>
<script>
    $('div').on('click', function () {
        alert('div')
        return false
    })
    $('p').on('click', function () {
        alert('p')
        return false
    })
    $('span').on('click', function () {
        alert('span')
        return false
    })
</script>
</body>
</html>

【6】页面载入

  • 当DOM载入就绪可以查询及操纵时绑定一个要执行的函数。这是事件模块中最重要的一个函数,因为它可以极大地提高web应用程序的响应速度。
// 写法1
$(document).ready(function(){
// 在这里写你的JS代码...
})

// 写法2
$(function(){
// 你在这里写你的代码
})

案例

// 文档加载完绑定事件,并且阻止默认事件发生:

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="x-ua-compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <title>登录注册示例</title>
  <style>
    .error {
      color: red;
    }
  </style>
</head>
<body>

<form id="myForm">
  <label for="name">姓名</label>
  <input type="text" id="name">
  <span class="error"></span>
  <label for="passwd">密码</label>
  <input type="password" id="passwd">
  <span class="error"></span>
  <input type="submit" id="modal-submit" value="登录">
</form>

<script src="jquery-3.2.1.min.js"></script>
<script src="s7validate.js"></script>
<script>
  function myValidation() {
    // 多次用到的jQuery对象存储到一个变量,避免重复查询文档树
    var $myForm = $("#myForm");
    $myForm.find(":submit").on("click", function () {
      // 定义一个标志位,记录表单填写是否正常
      var flag = true;
      $myForm.find(":text, :password").each(function () {
        var val = $(this).val();
        if (val.length <= 0 ){
          var labelName = $(this).prev("label").text();
          $(this).next("span").text(labelName + "不能为空");
          flag = false;
        }
      });
      // 表单填写有误就会返回false,阻止submit按钮默认的提交表单事件
      return flag;
    });
    // input输入框获取焦点后移除之前的错误提示信息
    $myForm.find("input[type!='submit']").on("focus", function () {
      $(this).next(".error").text("");
    })
  }
  // 文档树就绪后执行
  $(document).ready(function () {
    myValidation();
  });
</script>
</body>
</html>


【7】事件委托

  • 事件委托是通过事件冒泡的原理,利用父标签去捕获子标签的事件。

案例

// 点击任意一个按钮都会弹窗 包括后续通过dom操作动态添加的按钮
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="jQuery.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/js/bootstrap.min.js"></script>
</head>
<body>
<button>是兄弟就来砍我</button>
<script>
  $('body').on('click','button',function (){
    alert('一刀999')
  })
</script>
</body>
</html>

【四】动画效果

// 基本
show([s,[e],[fn]])
hide([s,[e],[fn]])
toggle([s],[e],[fn])
// 滑动
slideDown([s],[e],[fn])
slideUp([s,[e],[fn]])
slideToggle([s],[e],[fn])
// 淡入淡出
fadeIn([s],[e],[fn])
fadeOut([s],[e],[fn])
fadeTo([[s],o,[e],[fn]])
fadeToggle([s,[e],[fn]])
// 自定义(了解即可)
animate(p,[s],[e],[fn])

标签:jQuery,function,hide,标签,元素,语法,id,属性
From: https://www.cnblogs.com/Hqqqq/p/18092679

相关文章

  • Vue项目,用模板语法{{}}插值渲染文本,文本不能换行的坑
    {{contentTitle}}data(){return{contentTitle:第一行第二行,}},contentTitle这个变量赋的值是,ES6的字符模板根据说明,在这个字符模板内换行,会直接输出换行,不需要添加什么\n,这类东西。但渲染出来的文本根本没有换行,是这样的:第一行第二行(换......
  • 设备树DTS简介及DTS基本语法
    参考资料:https://www.bilibili.com/video/BV1fJ411i7PB?p=16&vd_source=432ba293ecfc949a4174ab91ccc526d6 在linux3.1版本引入设备树设备树用来描述板级信息编译设备树:makeall//全编译,包括内核镜像和dtbmakedtbs//编译所有的设备树文件makeimx6ull-14x1......
  • 前端基础之jQuery重要补充
    一、阻止事件默认行为和阻止事件冒泡1、阻止事件默认行为阻止事件的默认行为是指阻止浏览器在特定事件发生时执行的默认操作。这对于定制用户交互体验非常有用,可以通过阻止默认行为来实现自定义行为或效果。<script>$('#d2').click(function(){$('#d1').text('......
  • 前端基础之jQuery引入
    一、jQuery介绍(1)JavaScript库JavaScript库:即library,是一个封装好的特定的集合(方法和函数)。从封装一大堆函数的角度理解库,就是在这个库中,封装了很多预先定义好的函数在里面,比如动画animate、hide、show,比如获取元素等。简单理解:就是一个JS文件,里面对我们原生js代码进行了封......
  • python基本概念及语法
    Python是一种高级、面向对象的编程语言,它具有简洁、易读的语法,适用于多种领域的应用开发。Python的基本概念包括:变量:用于存储数据的容器,可以是数字、字符串、列表等类型。在Python中,不需要事先声明变量的类型,可以直接赋值使用。示例:x=5#整数变量y="Hello"#字符......
  • jquery在父组件中访问子组件的DOM元素
    父组件1、引入子组件importMarkDialogfrom"@/views/home/digitalMap/markDialog.vue";2、注册子组件components:{MarkDialog},3、使用子组件<mark-dialogref="markDialog"></mark-dialog>4、通过jquery访问子组件的dom元素constchildDomElem......
  • 深入理解 C++ 语法:从基础知识到高级应用
    C++语法让我们将以下代码分解以更好地理解它:示例#include<iostream>usingnamespacestd;intmain(){cout<<"HelloWorld!";return0;}示例解释第1行:#include<iostream>是一个头文件库,它让我们可以使用输入和输出对象,比如cout(在第5行使用)。头文件为......
  • Markdown常用语法备忘手册
    数学公式/LaTeX语法矩阵先来一份示例$$\left[\begin{array}{r:c:l}a0&b1&c2\\\hlined&e&f\end{array}\right]$$说明:1.首尾的$$换成$可以将矩阵改成行内显示,即不单独换行;2.'\left['和'\right]'表示左右分别用'[]'包裹,也支持用'()�......
  • JQuery 点击不同Button进不同方法
    <scripttype="text/javascript"src="/js/jquery-3.2.0.min.js"></script> <scripttype="text/javascript">//$(document).ready(function(){//$("#showPwd").click(function()......
  • 图形化配置和Kconfig基本语法
    参考资料:https://www.bilibili.com/video/BV12E411h71h?p=32&vd_source=432ba293ecfc949a4174ab91ccc526d6 ubuntu下安装ncurses库:sudoapt-getinstallbuild-essentialsudoapt-getinstalllibncurses5-dev.config文件保存着uboot的配置项,使用menuconfig配置完uboo......