zoukankan      html  css  js  c++  java
  • 进击的Python【第十六章】:Web前端基础之jQuery

    进击的Python【第十六章】:Web前端基础之jQuery

    一、什么是 jQuery ?

    jQuery是一个JavaScript函数库。

    jQuery是一个轻量级的"写的少,做的多"的JavaScript库。

    jQuery库包含以下功能:

    • HTML 元素选取
    • HTML 元素操作
    • CSS 操作
    • HTML 事件函数
    • JavaScript 特效和动画
    • HTML DOM 遍历和修改
    • AJAX
    • Utilities

    提示: 除此之外,Jquery还提供了大量的插件。

    这里有一个jquery操作速查网站:http://jquery.cuishifeng.cn/

    jquery有三个版本:

    1.X   2.X   3.X

    原则上是最新最好,最新的代表最新最高级的功能,但是也包含了最新的未被发现的bug,而且对老版本的浏览器不支持,兼容性相对1.X版本要差,这里推荐1.X版本,兼容性最好,功能也不差。

    下载

    官网:https://jquery.com/

    这里提供1.12.4的下载链接

    https://code.jquery.com/jquery-1.12.4.js
    https://code.jquery.com/jquery-1.12.4.min.js (这是压缩版)

    一、查找元素

    导入jquery

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        
    </head>
    <body>
    
        <script src="jquery-1.12.4.js"></script>
    </body>
    </html>

    查找元素

    选择器实例选取
    * $("*") 所有元素
    #id $("#lastname") id="lastname" 的元素
    .class $(".intro") class="intro" 的所有元素
    .class,.class $(".intro,.demo") class 为 "intro" 或 "demo" 的所有元素
    element $("p") 所有 <p> 元素
    el1,el2,el3 $("h1,div,p") 所有 <h1>、<div> 和 <p> 元素
         
    :first $("p:first") 第一个 <p> 元素
    :last $("p:last") 最后一个 <p> 元素
    :even $("tr:even") 所有偶数 <tr> 元素,索引值从 0 开始,第一个元素是偶数 (0),第二个元素是奇数 (1),以此类推。
    :odd $("tr:odd") 所有奇数 <tr> 元素,索引值从 0 开始,第一个元素是偶数 (0),第二个元素是奇数 (1),以此类推。
         
    :first-child $("p:first-child") 属于其父元素的第一个子元素的所有 <p> 元素
    :first-of-type $("p:first-of-type") 属于其父元素的第一个 <p> 元素的所有 <p> 元素
    :last-child $("p:last-child") 属于其父元素的最后一个子元素的所有 <p> 元素
    :last-of-type $("p:last-of-type") 属于其父元素的最后一个 <p> 元素的所有 <p> 元素
    :nth-child(n) $("p:nth-child(2)") 属于其父元素的第二个子元素的所有 <p> 元素
    :nth-last-child(n) $("p:nth-last-child(2)") 属于其父元素的第二个子元素的所有 <p> 元素,从最后一个子元素开始计数
    :nth-of-type(n) $("p:nth-of-type(2)") 属于其父元素的第二个 <p> 元素的所有 <p> 元素
    :nth-last-of-type(n) $("p:nth-last-of-type(2)") 属于其父元素的第二个 <p> 元素的所有 <p> 元素,从最后一个子元素开始计数
    :only-child $("p:only-child") 属于其父元素的唯一子元素的所有 <p> 元素
    :only-of-type $("p:only-of-type") 属于其父元素的特定类型的唯一子元素的所有 <p> 元素
         
    parent > child $("div > p") <div> 元素的直接子元素的所有 <p> 元素
    parent descendant $("div p") <div> 元素的后代的所有 <p> 元素
    element + next $("div + p") 每个 <div> 元素相邻的下一个 <p> 元素
    element ~ siblings $("div ~ p") <div> 元素同级的所有 <p> 元素
         
    :eq(index) $("ul li:eq(3)") 列表中的第四个元素(index 值从 0 开始)
    :gt(no) $("ul li:gt(3)") 列举 index 大于 3 的元素
    :lt(no) $("ul li:lt(3)") 列举 index 小于 3 的元素
    :not(selector) $("input:not(:empty)") 所有不为空的输入元素
         
    :header $(":header") 所有标题元素 <h1>, <h2> ...
    :animated $(":animated") 所有动画元素
    :focus $(":focus") 当前具有焦点的元素
    :contains(text) $(":contains('Hello')") 所有包含文本 "Hello" 的元素
    :has(selector) $("div:has(p)") 所有包含有 <p> 元素在其内的 <div> 元素
    :empty $(":empty") 所有空元素
    :parent $(":parent") 匹配含有子元素或者文本的元素。
    :hidden $("p:hidden") 所有隐藏的 <p> 元素
    :visible $("table:visible") 所有可见的表格
    :root $(":root") 文档的根元素
    :lang(language) $("p:lang(de)") 所有带有以 "de" 开头的 lang 属性值的 <p> 元素
         
    [attribute] $("[href]") 所有带有 href 属性的元素
    [attribute=value] $("[href='default.htm']") 所有带有 href 属性且值等于 "default.htm" 的元素
    [attribute!=value] $("[href!='default.htm']") 所有带有 href 属性且值不等于 "default.htm" 的元素
    [attribute$=value] $("[href$='.jpg']") 所有带有 href 属性且值以 ".jpg" 结尾的元素
    [attribute|=value] $("[title|='Tomorrow']") 所有带有 title 属性且值等于 'Tomorrow' 或者以 'Tomorrow' 后跟连接符作为开头的字符串
    [attribute^=value] $("[title^='Tom']") 所有带有 title 属性且值以 "Tom" 开头的元素
    [attribute~=value] $("[title~='hello']") 所有带有 title 属性且值包含单词 "hello" 的元素
    [attribute*=value] $("[title*='hello']") 所有带有 title 属性且值包含字符串 "hello" 的元素
    [name=value][name2=value2] $( "input[id][name$='man']" ) 带有 id 属性,并且 name 属性以 man 结尾的输入框
         
    :input $(":input") 所有 input 元素
    :text $(":text") 所有带有 type="text" 的 input 元素
    :password $(":password") 所有带有 type="password" 的 input 元素
    :radio $(":radio") 所有带有 type="radio" 的 input 元素
    :checkbox $(":checkbox") 所有带有 type="checkbox" 的 input 元素
    :submit $(":submit") 所有带有 type="submit" 的 input 元素
    :reset $(":reset") 所有带有 type="reset" 的 input 元素
    :button $(":button") 所有带有 type="button" 的 input 元素
    :image $(":image") 所有带有 type="image" 的 input 元素
    :file $(":file") 所有带有 type="file" 的 input 元素
    :enabled $(":enabled") 所有启用的元素
    :disabled $(":disabled") 所有禁用的元素
    :selected $(":selected") 所有选定的下拉列表元素
    :checked $(":checked") 所有选中的复选框选项
    .selector $(selector).selector 在jQuery 1.7中已经不被赞成使用。返回传给jQuery()的原始选择器
    :target $( "p:target" ) 选择器将选中ID和URI中一个格式化的标识符相匹配的<p>元素

    二、操作元素

     筛选

    $('#i1').next()
    $('#i1').nextAll()
    $('#i1').nextUntil('#ii1')
    				
    <div>
    	<a>asdf</a>
    	<a>asdf</a>
    	<a id='i1'>asdf</a>
    	<a>asdf</a>
    	<a id='ii1'>asdf</a>
    	<a>asdf</a>
    </div>
    				
    $('#i1').prev()
    $('#i1').prevAll()
    $('#i1').prevUntil('#ii1')
    				
    				
    $('#i1').parent()
    $('#i1').parents()
    $('#i1').parentsUntil()
    				
    $('#i1').children()
    $('#i1').siblings()
    $('#i1').find()
    $('li:eq(1)')
    $('li').eq(1)
    first()
    last()
    hasClass(class)
    

    文本操作

    $(..).text()           # 获取文本内容
    $(..).text(“<a>1</a>”) # 设置文本内容
    				
    $(..).html()
    $(..).html("<a>1</a>")
    				
    $(..).val()
    $(..).val(..)
    

    样式操作  

    addClass
    removeClass
    toggleClass
    

    属性操作

    # 专门用于做自定义属性
    $(..).attr('n')
    $(..).attr('n','v')
    $(..).removeAttr('n')
    				
    <input type='checkbox' id='i1'  />
    				
    				
    # 专门用于chekbox,radio
    $(..).prop('checked')
    $(..).prop('checked', true)
    PS: 
    index 获取索引位置
    

    事件绑定

    $('.c1').click()
    $('.c1').....
    					
    $('.c1').bind('click',function(){
    						
    })
    					
    $('.c1').unbind('click',function(){
    						
    })
    					
    *******************
    $('.c').delegate('a', 'click', function(){
    					
    })
    $('.c').undelegate('a', 'click', function(){
    					
    })
    					
    $('.c1').on('click', function(){
    					
    })
    $('.c1').off('click', function(){
    					
    })
    					
    阻止事件发生
    	return false
    					
    # 当页面框架加载完成之后,自动执行
    $(function(){
    					
    $(...)
    					
    })
    

    jQuery扩展

    - $.extend        $.方法
    - $.fn.extend     $(..).方法
    			
    (function(){
    	var status = 1;
    	// 封装变量
    })(jQuery)
    

      

  • 相关阅读:
    浏览器允许跨域运行字符串
    检查失败,<master>分支有过其他更新,请先在本地合并<master>分支的代码
    微信公众号开发点点滴滴
    手机上的软件开发应该
    见过写过最好的代码
    Prometheus之新版node_exporter监控主机设置
    Granfana设置邮件告警
    linux 中添加自己的库路径的方法 cannot open shared object file: No such file or directory
    C# this.Invoke()的作用与用法
    C#中this.Invoke()中委托的定义
  • 原文地址:https://www.cnblogs.com/yunweiqiang/p/7474822.html
Copyright © 2011-2022 走看看