zoukankan      html  css  js  c++  java
  • 【jQuery00】什么是jQuery,为什么要学jQuery,配置jQuery环境,解决冲突,大致使用流程

    OK,首先来了解下什么是jQuery,我们可以简单的理解为jQuery是一个JavaScript函数库是一个轻量级的“写得少,做得多”的JavaScript库。

    特色有以下这些方面:

    ·使用多浏览器开源选择器引擎 Sizzle(jQuery 项目的派生产品)进行 DOM 元素选择
    ·基于 CSS 选择器的 DOM 操作,使用元素的名称和属性(如 id 和 class)作为选择 DOM 中节点的条件
    ·事件
    ·特效和动画
    ·Ajax
    ·Deferred 和 Promise 对象来控制异步处理
    ·JSON 解析
    ·通过插件扩展
    ·工具函数,如特征检测
    ·现代浏览器中本地的兼容性方法,但对于旧版浏览器需要后备(fallback)方法,比如 inArray()和 each()
    ·多浏览器(不要与跨浏览器混淆)支持

    虽然jQuery正在逐渐退出历史的舞台,但是作为一个前端初学者,花个几天时间来学习了解一下他的思想还是很有必要的。

    那么,我们开始!

    首先是配置jQuery环境,进入jQuery的官方网站jQuery来下载最新的jQuery文件到本地,然后再引入到项目中即可。引入代码示例:

    <head>
    <script type="text/javascript" src="jquery.js"></script>
    </head>
    

    下面给出jQuery第一个页面的应用示例:

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="utf-8">
            <title>第一个jQuery小程序</title>
            <script type="text/javascript" src="C:Users59990DocumentsjQueryjquery-3.5.1.min.js"></script>
        </head>
    
        <body>
            <div class="box">
                <ul class="menu">
                    <li class="level1">
                        <a href="#">春天</a>
                        <ul class="level2">
                            <li>春意盎然</li>
                            <li>春意盎然</li>
                            <li>春意盎然</li>
                            <li>春意盎然</li>
                        </ul>
                    </li>
                    <li class="level1">
                        <a href="#">夏天</a>
                        <ul class="level2">
                            <li>夏日炎炎</li>
                            <li>夏日炎炎</li>
                            <li>夏日炎炎</li>
                            <li>夏日炎炎</li>
                        </ul>
                    </li>
                    <li class="level1">
                        <a href="#">秋天</a>
                        <ul class="level2">
                            <li>秋高气爽</li>
                            <li>秋高气爽</li>
                            <li>秋高气爽</li>
                            <li>秋高气爽</li>
                        </ul>
                    </li>    
                </ul>
            </div>
            <script type="text/javascript">
                // 等待dom元素加载完毕
                $(document).ready(
                    function(){
                        $(".level1>a").click(function(){
                            $(this).addClass("current") // 给当前元素添加“current”样式
                            .next().show()  // 下一个元素显示
                            .parent().siblings().children("a").removeClass("current") // 父元素的同辈元素的子元素a移除“current”样式
                            .next().hide(); // 他们的下一个元素隐藏
                            return false;
                        })
                    });
            </script>
        </body>
    </html>
    

    jQuery对象

    jQuery对象就是通过包装DOM对象后产生的对象,可以使用jQuery里的方法。比如:

    $("$syl").html(); // 获取id为syl的元素内的html代码,html()是jQuery中的方法
    

    这段代码等同于:

    document.getElementById("syl").innerHTML;
    

    ** 额外要注意的是 **

    jQuery对象不等同于DOM对象,但是他们之间可以相互转换
    *** jQuery对象转换为DOM对象 ***

    var $cr = $("#cr");
    var cr = $cr[0];
    

    或者:

    var $cr = $("#cr");
    var cr = $cr.get(0);  // DOM 对象
    

    *** DOM对象转换为jQuery对象 ***

    var cr = document.getElementById("cr");
    var $cr = $(cr); // jQuery对象
    

    解决冲突

    并不是只有jQuery框架使用$符号,如果跟其他框架重复了怎么办呢,jQuery团队考虑到了这个问题,并实现了noConflict()方法。
    例如:

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="utf-8">
            <title>Day03消除冲突</title>
            <script type="text/javascript" src="C:Users59990DocumentsjQueryjquery-3.5.1.min.js"></script>
        </head>
    
        <body>
            <p>这是一个段落</p>
            <button>点我</button>
    
            <script type="text/javascript">
            /*
                // 等待DOM元素加载完毕
                $.noConflict(); // 释放对$的控制
                jQuery(document).ready(function(){
                    jQuery("button").click(function(){
                        jQuery("p").text("jQuery仍在工作!");
                    })
                });
            */
                
                // 或者
                // 等待DOM元素加载完毕
                var jq = $.noConflict();
                jq(document).ready(function(){
                    jq("button").click(function(){
                        jq("p").text("jQuery仍在工作!")
                    })
                });
            </script>
        </body>
    </html>
    

    总结

    ok 又到了总结阶段,写一点个人的小想法,这是我第一次接触jQuery,目前看起来还比较简单,前端的知识都是比较多且杂的,得慢慢学。今天了解了jQuery的一些历史,知道了怎么去在文件中引用它,也实践了几个小东西,知道了jQuery对象和DOM对象的区别,也学会了怎么解决jQuery和其他库的冲突。
    总而言之,首先等待DOM元素加载完毕,也就是$(document).ready(); 这个ready里边的参数呢是一个函数function(){},而你又可以在这个函数里去通过jQuery的选择器去对页面中的某些元素做相应的操作,学习中发现click()这个函数应用频率很高,具体使用就是jq选择器.click(),然后里边的参数就是一个函数,这个函数会在这个元素被点击的时候触发,嗯,就这样吧。

  • 相关阅读:
    python:一个比较有趣的脚本
    opencv:图像模糊处理
    opencv:基本图形绘制
    opencv:摄像头和视频的读取
    C++:lambda表达式
    opencv:傅里叶变换
    opencv:创建滑动条
    opencv:通过滑动条调节亮度和对比度
    【源码】防抖和节流源码分析
    【css】最近使用的两种图标字体库
  • 原文地址:https://www.cnblogs.com/mqjing/p/13629284.html
Copyright © 2011-2022 走看看