jQuery的实例及必知重要的jQuery选择器详解

Jquery能做什么

访问和操作DOM元素
 
控制页面样式
 
 对页面事件进行处理
 
 扩展新的jQuery插件
 
与Ajax技术完美结合

Jquery的优势

体积小,压缩后只有100KB左右
 
l强大的选择器
 
出色的DOM封装
 
l可靠的事件处理机制
 
出色的浏览器兼容性
 
使用隐式迭代简化编程
 
丰富的插件支持

jQuery的知识的分解:

1.关于window.onload和$(function(){})区别
 
解析:window.onload等待页面上所有资源(html标签,css,img,js)都加载完成后,才执行,包括(文本素材,图片,js,css)
 
$(function(){}):等待页面上的标签素材加载完成后就开始执行
 
第二点:
 
Window.onload只能调用一次
 
$(function(){})可以调用多次
 
2.怎么通过Jquery设置样式
 
1).通过$(“选择器”).css(“属性名”,”属性值”);
 
//这里的书写的属性名和css中书写的一致
 
2).$(“选择器”).html():获取两个标签之间的html代码
 
3).$(“选择器”).addClass(“属性值”)
 
可以动态的改变dom文档结构。进而设置样式。
 
3.DOM对象和Jquery对象的转换
 
jquery对象转换成 dom对象

jquery提供了两种方法将一个jquery对象转换成一个dom对象,即[index]和get(index)。
 
ar cr= cr=("#cr"); //jquery对象
var cr = $cr[0]; //dom对象 也可写成 var cr=$cr.get(0);
alert(cr.checked); //检测这个checkbox是否给选中

dom对象转换成jquery对象

对于一个dom对象,只需要用$()把dom对象包装起来,就可以获得一个jquery对象了,方法为$(dom对象);

代码:

var cr=document.getElementById("cr"); //dom对象
var cr= cr=(cr); //转换成jquery对象

光棒效果案例:

js代码:

$(function () {
        var lis = document.getElementsByTagName('li');

        for (var i = 0; i < lis.length; i++) {
          lis[i].onmouseover = function () {
            this.style.background = 'red';
          };
          lis[i].onmouseout = function () {
            this.style.background = '';

          }
        }
      });

jQuery的代码:

$(function () {
        $('li').mouseover(function () {
          $(this).css('background','red');
        }).mouseout(function () {
          $(this).css('background', '');
        })
      });

jQuery瀑布流案例:

<script>
  var margin = 10;//这里设置间距
  var li = $("li");//这里是区块名称
  var li_W = li[0].offsetWidth + margin;//取区块的实际宽度(包含间距,这里使用源生的offsetWidth函数,不适用jQuery的width()函数是因为它不能取得实际宽度,例如元素内有pandding就不行了)
  function liuxiaofan() {//定义成函数便于调用
    var h = [];//记录区块高度的数组
    var n = document.documentElement.offsetWidth / li_W | 0;//窗口的宽度除以区块宽度就是一行能放几个区块
    for (var i = 0; i < li.length; i++) {//有多少个li就循环多少次
      li_H = li[i].offsetHeight;//获取每个li的高度
      if (i < n) {//n是一行最多的li,所以小于n就是第一行了
        h[i] = li_H;//把每个li放到数组里面
        li.eq(i).css("top", 0);//第一行的Li的top值为0
        li.eq(i).css("left", i * li_W);//第i个li的左坐标就是i*li的宽度
      }
      else {
        min_H = Math.min.apply(null, h);//取得数组中的最小值,区块中高度值最小的那个
        minKey = getarraykey(h, min_H);//最小的值对应的指针
        h[minKey] += li_H + margin;//加上新高度后更新高度值
        li.eq(i).css("top", min_H + margin);//先得到高度最小的Li,然后把接下来的li放到它的下面
        li.eq(i).css("left", minKey * li_W);  //第i个li的左坐标就是i*li的宽度
      }
      $("h3").eq(i).text("编号:" + i + ",高度:" + li_H);//把区块的序号和它的高度值写入对应的区块H3标题里面
    }
  }
  /* 使用for in运算返回数组中某一值的对应项数(比如算出最小的高度值是数组里面的第几个) */
  function getarraykey(s, v) { for (k in s) { if (s[k] == v) { return k; } } }
  /*这里一定要用onload,因为图片不加载完就不知道高度值*/
  window.onload = function () { liuxiaofan(); };
  /*浏览器窗口改变时也运行函数*/
  window.onresize = function () { liuxiaofan(); };
</script>

JQuery选择器

解析:为了更好的或者是更快的从复杂的DOM树中找到我们需要的一类标签

1.层次选择器

<!-- 当点击h2元素时,为#menu下的<span>元素添加色为#09F的颜色背景 -->
  <!-- <script type="text/javascript">
    $(function () {
      $('h2').click(function () {
        $('#menu span').css('background-color','#09F');
      });
    });
  </script>-->

2.基本选择器

<!-- 为标签选择器添加样式 -->
  <script type="text/javascript">
    $(function () {
      $('h2').click(function () {
        $('h3').css('background-color', '#09F');

      });
    });
  </script>

3.基本过滤选择器

<script type="text/javascript">
    $(function () {
      $('h2').click(function () {
        //$('li:first').css('background-color', '#09F');//第一个
        //$('li:last').css('background-color', '#09F');//最后一个
        //$('li:not(.three)').css('background-color', '#09F');//class不为three的元素
        // $('li:even').css('background-color', '#09F');//索引值为偶数的元素
        // $('li:eq(1)').css('background-color', '#09F');//索引值为1的元素
         //$('li:gt(1)').css('background-color', '#09F');//索引值大于1的元素
        //$('li:lt(1)').css('background-color', '#09F');//索引值小于1的元素
        //$(':header').css('background-color', '#09F');//所有标题的元素
        $(':focus').css('background-color', '#09F');//获取焦点的元素

      });
    });
  </script>

4.可见性过滤选择器

<script src="js/jquery-1.8.3.js"></script>
  <script type="text/javascript">
    $(function () {
      // $('p:hidden').show();//显示文字
      $('p:visible').hide();//隐藏文字
    });
  </script>
  <style type="text/css">
    #txt_show
    {
      display:none;color:#00C;
    }
    #txt_hide
    {
      display:block;color:#F30;
    }
  </style>
</head>
<body>
  <p id="txt_hide">点击按钮,我会被隐藏哦~</p>
   <p id="txt_show">隐藏的我,被显示了,嘿嘿~</p>
  <input type="button" name="show" value="点击显示文字 " />
   <input type="button" name="hide" value="点击隐藏文字 " />
</body>

5.属性选择器

<!--改变class属性的值为odds的元素的背景颜色 -->
   <script type="text/javascript">
     $(function () {
       $("h2").click(function () {
         $("[class=odds]").css("background-color", "#FFFFFF");
       })
     });
  </script>

以上这篇jQuery的实例及必知重要的jQuery选择器详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 举例讲解jQuery中可见性过滤选择器的使用

    可见性过滤器 可见性过滤器根据元素的可见性和不可见性来选择相应的元素. 过滤器名 jQuery 语法 说明 返回 :hidden  $(':hidden')  选取所有不可见元素 集合元素 :visible  $(':visible')  选取所有可见元素 集合元素 $('p:hidden).size(); //元素p 隐藏的元素 $('p:visible').size(); //元素p 显示的元素 注意::hidden 过滤器一般是包含的内容为:CSS 样式为display:none.inpu

  • jQuery选择器基础入门教程

    本文实例讲述了jQuery选择器用法.分享给大家供大家参考,具体如下: 什么是jQuery选择器 使用JavaScript操作页面上得DOM元素时,首先要获取DOM元素.但是原始的javascript只元件根据ID或者TagName获取DOM对象. 在jQuery中则完全不同,jQuery提供了异常强大的选择器用以帮助我们获取页面上的对象,并且将对象以jquery对象的形式返回. 首先来看看什么是选择器. //根据id获取jQuery对象 var jQueryObject=$("#testDiv

  • 浅析jQuery事件之on()方法绑定多个选择器,多个事件

    $(document).on('click', '#header .top, #main .btn', function () { // code... }); on()方法绑定多个事件 $("table.planning_grid").on({ mouseenter: function() { // Handle mouseenter... }, mouseleave: function() { // Handle mouseleave... }, click: function()

  • jQuery选择器及jquery案例详解(必看)

    JQuery选择器 解析:为了更好的或者是更快的从复杂的DOM树中找到我们需要的一类标签 1.层次选择器 <!-- 当点击h2元素时,为#menu下的<span>元素添加色为#09F的颜色背景 --> <!-- <script type="text/javascript"> $(function () { $('h2').click(function () { $('#menu span').css('background-color','#0

  • 简单讲解jQuery中的子元素过滤选择器

    子元素过滤器的过滤规则是通过父元素和子元素的关系来获取相应的元素. $('li:first-child').css('background', '#ccc'); //每个父元素第一个li 元素 $('li:last-child').css('background', '#ccc'); //每个父元素最后一个li 元素 $('li:only-child').css('background', '#ccc'); //每个父元素只有一个li 元素 $('li:nth-child(odd)').css(

  • jQuery的内容过滤选择器学习教程

    内容过滤器的过滤规则主要是包含的子元素或文本内容上. $('div:contains("xxx")').css('background', '#ccc'); //选择元素文本节点含有xxx 文本的元素 $('div:empty').css('background', '#ccc'); //选择空元素 $('ul:has(.red)').css('background', '#ccc'); //选择子元素含有class 是red 的元素 $(':parent').css('backgro

  • jQuery中的基本选择器用法学习教程

    一.简单选择器 在使用jQuery 选择器时,必须使用"$()"函数来包装CSS 规则.而CSS 规则作为参数传递到jQuery 对象内部后,再返回包含页面中对应元素的jQuery 对象.随后,就可以对这个获取到的DOM 节点进行行为操作了. #box {//使用ID 选择器的CSS 规则 color:red;//将ID 为box 的元素字体颜色变红 } 在jQuery 选择器里,我们使用如下的方式获取同样的结果: $('#box').css('color', 'red');//获取D

  • jQuery插件实现适用于移动端的地址选择器

    最近在工作中需要用到地址选择器,像下面这样的,本想在网上找一个,可是没找到,于是自己写了个jquery插件. 直接上代码吧: var provinces = { "A": { "安徽":["合肥市","芜湖市","蚌埠市","淮南市","马鞍山市","淮北市","铜陵市","安庆市","黄山市&qu

  • jQuery的实例及必知重要的jQuery选择器详解

    Jquery能做什么 访问和操作DOM元素   控制页面样式    对页面事件进行处理    扩展新的jQuery插件   与Ajax技术完美结合 Jquery的优势 体积小,压缩后只有100KB左右   l强大的选择器   出色的DOM封装   l可靠的事件处理机制   出色的浏览器兼容性   使用隐式迭代简化编程   丰富的插件支持 jQuery的知识的分解: 1.关于window.onload和$(function(){})区别   解析:window.onload等待页面上所有资源(ht

  • .NET必知的EventCounters性能指标监视器详解

    在.NET我们对于性能指标监控,其实常见的有两个方法,一个是CLI工具dotnet-counters而另一个是代码级别的EventListener. 使用dotnet-counters dotnet-counters是一个性能指标监视工具,用于临时运行状态监视和初级性能调查.它可以观察通过 EventCounter API发布的性能计数器值.例如,可以快速监视 CPU 使用情况或 .NET Core 应用程序中引发的异常率,以了解在使用 PerfView 或 dotnet-trace 深入调查更

  • 程序员必知35个jQuery 代码片段

    jQuery如今已经成为Web开发中最流行的JavaScript库,通过jQuery和大量的插件,你可以轻松实现各种绚丽的效果.本文将为你介绍一些jquery实用的技巧,希望可以帮助你更加高效地使用jQuery. 收集的35个 jQuery 小技巧/代码片段,可以帮你快速开发. 1. 禁止右键点击 $(document).ready(function(){ $(document).bind("contextmenu",function(e){ return false; }); });

  • Golang必知必会之Go Mod命令详解

    目录 一.go mod 是什么? 二.详细命令 1. init 2.download 3.tidy 4.graph 5.edit 5.vendor 5.verify 5.why 补充:golang开启mod后import报红解决 总结 一.go mod 是什么? go modules 官方定义为: 模块是相关Go包的集合.modules是源代码交换和版本控制的单元.go命令直接支持使用modules,包括记录和解析对其他模块的依赖性.modules替换旧的基于GOPATH的方法来指定在给定构建中

  • jQuery中each()、find()和filter()等节点操作方法详解(推荐)

    1.each(callback) 官方解释: 返回值:jQuery 概述 以每一个匹配的元素作为上下文来执行一个函数. 意味着,每次执行传递进来的函数时,函数中的this关键字都指向一个不同的DOM元素(每次都是一个不同的匹配元素).而且,在每次执行函数时,都会给函数传递一个表示作为执行环境的元素在匹配的元素集合中所处位置的数字值作为参数(从零开始的整型). 返回 'false' 将停止循环 (就像在普通的循环中使用 'break').返回 'true' 跳至下一个循环(就像在普通的循环中使用'

  • jQuery过滤选择器详解

    过滤选择器 过滤选择器主要是通过特定的过滤规则来筛选出所需的 DOM元素,该选择器都以":"开头 按照不同的过滤规则,过滤选择器可以分为基本过滤,内容过滤,可见性过滤,属性过滤,子元素过滤和表单对象属性过滤选择器. 基本过滤选择器 基本过滤选择器示例 改变第一个 div元素的背景色为 # bbffaa 改变最后一个 div元素的背景色为 # bbffaa 改变class不为 one的所有 div元素的背景色为 # bbffaa 改变索引值为偶数的 div元素的背景色为 # bbffaa

  • jQuery Json数据格式排版高亮插件json-viewer.js使用方法详解

    jQuery Json数据格式排版高亮插件json-viewer.js使用方法详解 1.插件介绍: jquery.json-viewer.js是一款查看json格式数据的jquery插件.它可以将混乱的json数据漂亮的方式展示在页面中,并支持节点的伸展和收缩和语法高亮等功能. 2.代码演示: 1).首先引入jquery和json.viewer.js插件 <script src="http://www.jq22.com/jquery/jquery-1.10.2.js">&l

  • jQuery Ajax的readyState和status的区别和使用详解

    在前几篇分析了jquery的ajax异步和同步,以及异常的一些处理,感觉还没有把ajax的readyState和status说清楚.今天就来说说ajax状态的那点事. jquery ajax函数源代码是这样的: var getXmlHttpRequest = function () { if (window.XMLHttpRequest) { //主流浏览器提供了XMLHttpRequest对象 return new XMLHttpRequest(); } else if (window.Act

  • jQuery AJAX 方法success()后台传来的4种数据详解

    1.后台返回一个页面 js代码 /**(1)用$("#content-wrapper").html(data);显示页面*/ $.ajax({ async : false, cache : false, type : 'POST', url : 'area/prepareCreate', error : function() { alert('smx失败 '); }, success : function(data) { $("#content-wrapper").

  • jQuery.validate.js表单验证插件的使用代码详解

    Validate Validate是基于jQuery的一款轻量级验证插件,内置丰富的验证规则,还有灵活的自定义规则接口,HTML.CSS与JS之间的低耦合能让您自由布局和丰富样式,支持input,select,textarea的验证. 效果: 代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="vi

随机推荐