zoukankan      html  css  js  c++  java
  • JQuery中美元符号$

    1. 概述

    前端技术得更新换代实在太快,JQuery可能已经不再适合着重学习,不过JQuery得思想已经融入了很多前端框架技术之中,比如这个美元符号imglink2,总是可以在一些地方看到,作为最开始使用imglink2得JS库,就学习下JQuery中imglink2得使用。

    2. 详论

    2.1. 加载脚本

    在HTML页面中引入原生的JS脚本一般都会这样开头:

    window.onload=function(){
        Func1();
        Func2();
        Func3();
        .....
    }
    

    使用window.onload()的原因是因为一般都会希望直到网页加载完毕后,再立刻执行JS脚本的操作,否则会造成在执行JS脚本的时候, HTML文档没有渲染完成,DOM树是不完整,获取DOM中元素未定义的错误。

    与window.onload()相对应的,包含JQuery或者采用相似技术的框架会这样加载js脚本:

    $(document).ready(function(){ 
        Func1();
        Func2();
        Func3();
        .....
    });
    

    $(document)表示的就是选择整个文档对象,.ready()就是DOM加载完成时的相应事件。这个写法进一步简化,就是如下的加载方案:

    <!DOCTYPE html>
    <html>
    
    <head>
        <meta charset="utf-8">
        <title>样例</title>
        <script src="./3rdParty/jquery-3.5.1.js">
        </script>
        <script>
            $(function () {       
                console.log(jQuery.fn.jquery);
            });
        </script>
    </head>
    
    <body>
        <p>这是一个段落。</p>
    </body>
    
    </html>
    

    当然,window.onload与jQuery ready()两种加载方式还是有区别的:
    imglink1

    2.2. 选择器

    可以认为JQuery的美元符号imglink2就是一种选择器,基于已经存在的 CSS 选择器(当然不局限于),能够选取网页中的各种元素。CSS有三种常用的选择器:元素选择器、ID选择器和类选择器;JQuery也有对应的选择器。

    2.2.1. 元素选择器

    下面例子展示通过imglink2实现选取标签元素,实现了一个效果:每次点击按钮,就会修改P元素的颜色属性。

    <!DOCTYPE html>
    <html>
    
    <head>
        <meta charset="utf-8">
        <title>样例</title>
        <script src="./3rdParty/jquery-3.5.1.js">
        </script>
        <script>
            $(function () {
                var active = false;
                $("button").click(function () {                
                    if(active){
                        $("p").css("color","#ff0000");
                    }else{              
                        $("p")[0].style.color = "#00ff00";                   
                    }   
                    active = !active;             
                })
            });
        </script>
    
        <style type="text/css">
            p {
                color:#ff0000;
            }
        </style>
    
    </head>
    
    <body>
        <p>这是一个段落。</p>
        <button>点我</button>
    </body>
    
    </html>
    

    通过$选择器,可以实现获取html中的标签元素,从而进一步实现修改对应的CSS属性。

    2.2.2. ID选择器

    给上面那个例子加上另外一个P标签的段落,id属性设置为test,那么可以像设置css选择器一样设置$()的参数:

    <!DOCTYPE html>
    <html>
    
    <head>
        <meta charset="utf-8">
        <title>样例</title>
        <script src="./3rdParty/jquery-3.5.1.js">
        </script>
        <script>
            $(function () {
                var active = false;
                $("button").click(function () {                
                    if(active){
                        $("#test").css("color","#ff0000");
                    }else{                         
                        $("p#test")[0].style.color = "#00ff00";                   
                    }   
                    active = !active;             
                })
            });
        </script>
    
        <style type="text/css">
            p {
                color:#ff0000;
            }
    
            #test {
                color:#0000ff;
            }
        </style>
    
    </head>
    
    <body>
        <p>这是一个段落。</p>
        <p id="test">这是另外一个段落</p>
        <button>点我</button>
    </body>
    
    </html>
    

    显示结果与之前的例子类似,同样是P标签元素,只有id值为test的元素改变颜色的功能生效了。

    2.2.3. 类选择器

    类选择器仍然与css一样,通过.符号+类名作为$()的参数,选择所有有相同class的元素:

    <!DOCTYPE html>
    <html>
    
    <head>
        <meta charset="utf-8">
        <title>样例</title>
        <script src="./3rdParty/jquery-3.5.1.js">
        </script>
        <script>
            $(function () {
                var active = false;
                $("button").click(function () {                
                    if(active){
                        $(".test1").css("color","#ffff00");
                    }else{                               
                        $("p.test1")[0].style.color = "#00ff00";     
                        $("h2.test1")[0].style.color = "#00ff00";                 
                    }   
                    active = !active;             
                })
            });
        </script>
    
        <style type="text/css">
            p {
                color:#ff0000;
            }
    
            #test {
                color:#0000ff;
            }
    
            .test1{
                color: #ffff00;
            }
        </style>
    
    </head>
    
    <body>
        <h2 class="test1">这是一个标题</h2>
        <p class="test1">这是一个段落。</p>
        <p id="test">这是另外一个段落</p>
        <button>点我</button>
    </body>
    
    </html>
    

    需要注意这时选取到元素可能元素标签可能不同。

    2.3. 引入方法

    在JQuery中,$还有个作用是引入各种JQuery已经封装好的方法,例如:

    imglink2.trim() 去除字符串两端的空格
    imglink2.each() 遍历一个数组或对象。
    imglink2.inArray() 返回一个值在数组中的索引位置。
    imglink2.type() 判断对象的类别
    imglink2.getJSON() 使用 AJAX 请求来获得 JSON 数据。
    ......

    3. 参考

    1. JavaScript window.onload
    2. jQuery 教程
    3. jQuery选择器大全整理
  • 相关阅读:
    Android Studio no debuggable applications解决方案2
    Android CountDownTimer倒计时器的使用
    git 创建分支并切换
    com.android.org.bouncycastle.jce.exception.ExtCertPathValidatorException: Could not validate certificate: current time:
    为什么调用 FragmentPagerAdapter.notifyDataSetChanged() 并不能更新其 Fragment
    Android 使WebView支持HTML5 Video(全屏)播放的方法
    使用retrofit注意
    解决 Android Studio 乱码问题
    Android视觉规范-间距规范与文字规范单位换算(dip、sp与px)
    教你如何删除WIN7系统文件以及无法删除的文件
  • 原文地址:https://www.cnblogs.com/charlee44/p/14057718.html
Copyright © 2011-2022 走看看