锋利的jquery学习笔记
1.$("#tt")获取的永远都是一个jquery对象,所以要判断页面上是否存在某个对象不能像js中
if($("#tt")){ }
而是通过:
if($("#tt").length > ){
}
ps:当页面中不存在id为tt的元素时,jQuery不会报错,而js中会报错
2. jQuery层选择器$("ancestor descendant")和$("parent>child")
<div>This is <strong>very</strong> important.</div>
<div>This is <em>really <strong>very</strong></em> important.</div>
好比一家人三代同堂,爷爷,父亲和你,这样话爷爷的子元素就是你父亲,同时你父亲也是爷爷的后代元素,而你只是爷爷的后代元素。
总结:后代元素包括子元素,子元素是指父亲的第一代。
3. jQuery选择器的种类
3.1 基本选择器
3.2 层次选择器
3.3 过滤选择器
3.3.1 基本过滤选择器
$("div:first") 选择第一个div;$("div:last")选择最后一个div;$("input:not(.myclass)")选择类不是myclass的input;$("input:even")选择索引为偶数的
input ;$("input:odd")选择索引为奇数的input;$("input:eq(1)")选择索引等于1的input元素;$("input:gt(1)")选择索引大于1input;$("input:lt(1)"
选择索引小于1的input;$(":header")选择头部如:h1……;$("div:animated")选择正在执行动画的div
3.3.2 内容过滤器
:contains(text)选择包含text的元素;:empty选择没有任何内容的元素包括文本;:parent选择有内容的元素包括文本;:has(selector)如:$("div:has('p')")
选择包含有p元素的div
3.3.3 可见性过滤器
:hidden 包括<input type="hidden"/>、<div style="display:none"/>和<div style="visibility:hidden"/>;:visible 如:$("div:visible")
3.3.4 属性过滤器
3.3.5 子元素过滤器
3.3.6 表单对象属性过滤器
3.4 表单选择器
3.5 选择器注意事项
3.5.1 选择器中含有特殊字符 ".","#","(","]"如:<div id="id#b"/> 则选择的时候要用\\转义 $("#id\\#b")
3.5.2 @符号 之前<div title="你好"/> $(" div[@title='']") 现在$("div[title='']")
3.5.3 选择器里带空格
$('.test:hidden')和$('.test :hidden')选取到的结果是不一样的一个是选取隐藏的类为test的元素,后者则是选取类为test的元素里面隐藏的元素
4. dom操作
4.1 元素添加
4.1.1 添加到元素里面 append、preappend
4.1.2 添加到元素外after、before
4.2 移除节点
4.2.1 彻底删除节点 remove
4.2.2 清空节点 empty
4.3 复制节点
4.3.1 复制节点内容不复制节点行为 clone().append()
4.3.2 复制节点内容并且复制节点行为 clone(true).append() ps:都是先复制然后添加到其他节点
4.4 替换节点
4.5 属性操作
4.6 包裹节点
4.7 样式操作
4.8 遍历节点
4.8.1 children()只考虑子元素不考虑任何后代元素
4.8.2 next() 匹配元素后面紧邻的同辈元素
4.8.3 prev() 匹配元素前面紧邻的同辈元素
4.8.4 siblings()获取当前元素前后所有的同辈元素
4.8.5 closest()获取离元素最近的元素 如:$("p").closest("li").removeclass("a")
4.9 css操作
4.9.1 CSS()操作style的属性时记得将属性用引号包含如:$("p").css({"font-size":30px,"background-color":red})否要用驼峰式写法如:fontSize:30px
4.9.2 获取元素高度 两种方法一是$("p").css("height")以及$("p").height() 区别是一个是获得属性可能是auto一个是具体的元素高度
4.9.3 获取设置元素宽度 width()
4.10 位置
4.10.1 offset() 相对于视窗的偏移注意两点:1.只针对可见元素 2.获取到两个属性一个top一个left
4.10.2 position 获取相对偏移
4.10.3 scrollTop()和scrollLeft()获取元素的滚动条距左边和顶部的距离
5.事件和动画
5.1 Windows.onload()和$(document).ready()的区别
执行时机:windows.onload()是在所有元素加载完成包括关联文件加载完成后才执行;而$(document).ready()是在dom元素准备就绪后执行
ps:windows.onload()相当于jQuery中的$(window).load()
多次使用:如页面加载完成后想通过windows.onload = one 和windows.onload = two 分别调用one和two但是结果只会调用two,因为onload只会绑定一个函数,后
面的会自动把前面的覆盖掉;而$(document).ready()可以追加事件如:$(document).ready(function(){one()}) 然后追加一个事件
$(document).ready(function(){tewo()})
简写方式:$(document).ready()可以简写成$(function(){}) 或者$().ready(function(){})
5.2 事件绑定
5.2.1 基本效果 $("p").bind("click",function(){执行代码})
5.2.2 加强效果(显示则隐藏否则显示)$("p").bind("click",function(){if($(this).is(":visible")){$(this).hide();}else{$(this).show();} })
5.2.3 改变绑定事件类型
5.2.4 简写绑定事件 实际上就是将之前的bind(“mouseout”,function(){})换成了.mouseout(function(){})
5.2.5 合成事件 hover(enter,leave)当光标悬停的时候就会触发第一个事件,当光标离开的时候就会触发第二个函数;toggle(fn1,fn2,fn3)会依次交替执行里面的函数
5.3 事件冒泡
5.3.1 什么是事件冒泡
5.3.2 怎么阻止事件冒泡 event.stopPropagation()
5.3.3 阻止默认行为 如a标签超链接跳转、表单验证当验证不成功时就要阻止默认的行为 event.preventDefault()
5.3.4 同时阻止冒泡事件和默认行为 则可以写成 return false
5.4 事件对象的属性
5.4.1 event.type() 返回事件类型
5.4.2 event.preventDefault() 阻止默认事件
5.4.3 event.stopPropagation() 阻止冒泡事件
5.4.4 event.target 获取触发事件的元素
5.4.5 event.pageX和event.pageY获取鼠标相对于屏幕的坐标
5.4.5 event.which在鼠标的点击事件中获取鼠标的左(1)、中(2)、右(3)
5.4.6 event.metaKey 返回的是一个布尔值如 if(event.metaKey == 1)用来判断ctrl键是否按下
5.4.7 event.originalEvent 指向原始的事件对象
5.5 移除事件
5.5.1 unbind() 移除绑定的事件给参数就是移除具体的事件如:$("p").unbind("click")不给参数就能移除所有的事件如:$("p").unbind()
语法结构如:unbind(type,function) Ps:type是事件类型,function是某个函数如:unbind("click",function1)
5.5.2 one() 也可以绑定事件,但是的事件只执行一次
5.6 模拟操作
$("p").trigger("click")简写:$("p").click()
5.7 绑定事件的其他用法
5.7.1 一次对多个事件进行绑定 如:$("p").bind("mouseover mouseout",function(){})
5.7.2 给元素绑定的多个事件用命名空间规范起来 如:$("p").bind("click .aaa",function(){}) $("p").bind("mouseover .aaa",function(){}) 删除绑定事件则
$("p").unbind(“.aaa”)
5.7.3 相同事件不同的命名空间执行$("p").trigger("click!")
5.8 jquery中的动画
5.8.1 show()和hide() 这个相当于.css("display","block或者inline")和.css("display","none")
5.8.2 show()和hide() 让元素动起来slow:600ms;normal:400ms;fast:200ms 如:show(slow)也可传一个数字如:show(1000)将在一秒内慢慢出现
5.8.3 fadeIn()和fadeOut() 只是改变元素的不透明度
5.8.4 slideUp()和slideDown() 通过改变元素的高度来讲元素隐藏 ps:让元素隐藏的方式有很多种,有通过改变高度的有通过改变透明度的,改变高度的,都可改变的。
jQuery中任何动画都可以传递两种参数一种是“slow”、"normal","fast"还有一种就是数字了代表具体的时间
5.8.5 animate({left:"50px"},speed,callback) 第一个参数就是包含样式属性跟值的映射,第二个是参数,第三个是回调函数
5.8.6 累加累减动画 animate({left:"+=50px",speed,callback})
5.8.7 多重动画
5.8.7.1 同时执行 animate({left:50px,height:"100px"},speed,callback)
5.8.7.2 顺序执行 animate({left:"50px"},speed,callback);animate({height:500px},speed,callback)
锋利的jquery学习笔记的更多相关文章
- 锋利的JQuery 学习笔记
第一章 认识JQuery ·页面加载事件(可以写多个ready())$(document).ready(function(){alert(“hello world”);} ...
- 锋利的jQuery学习笔记之jQuery选择器
在介绍jQuery选择器之前,先简单介绍一下CSS选择器---> 一.CSS选择器 常见的CSS选择器有以下几种: 选择器 语法 描述 示例 标签选择器 E{CSS规则} 以文档元素为选择符 t ...
- jQuery 学习笔记:jQuery 代码结构
jQuery 学习笔记:jQuery 代码结构 这是我学习 jQuery 过程中整理的笔记,这一部分主要包括 jQuery 的代码最外层的结构,写出来整理自己的学习成果,有错误欢迎指出. jQuery ...
- jQuery学习笔记(一)jQuery选择器
目录 jQuery选择器的优点 基本选择器 层次选择器 过滤选择器 表单选择器 第一次写博客,希望自己能够长期坚持,以写博客的方式作为总结与复习. 最近一段时间开始学习jQuery,通过写一个jQue ...
- jQuery 学习笔记
jQuery 学习笔记 一.jQuery概述 宗旨: Write Less, Do More. 基础知识: 1.符号$代替document.getElementById( ...
- jQuery学习笔记(一):入门
jQuery学习笔记(一):入门 一.JQuery是什么 JQuery是什么?始终是萦绕在我心中的一个问题: 借鉴网上同学们的总结,可以从以下几个方面观察. 不使用JQuery时获取DOM文本的操 ...
- jQuery学习笔记 - 基础知识扫盲入门篇
jQuery学习笔记 - 基础知识扫盲入门篇 2013-06-16 18:42 by 全新时代, 11 阅读, 0 评论, 收藏, 编辑 1.为什么要使用jQuery? 提供了强大的功能函数解决浏览器 ...
- JQuery学习笔记——层级选择器
JQuery学习笔记--层级选择器 上一篇学习了基础的五种选择,分别是id选择器,class选择器,element选择器,*选择器 和 并列选择器.根据手册大纲,这篇学习的是层级选择器. 选择器: 1 ...
- jQuery学习笔记之Ajax用法详解
这篇文章主要介绍了jQuery学习笔记之Ajax用法,结合实例形式较为详细的分析总结了jQuery中ajax的相关使用技巧,包括ajax请求.载入.处理.传递等,需要的朋友可以参考下 本文实例讲述了j ...
随机推荐
- hdu5884 Sort(二分+k叉哈夫曼树)
题目链接:hdu5884 Sort 题意:n个有序序列的归并排序.每次可以选择不超过k个序列进行合并,合并代价为这些序列的长度和.总的合并代价不能超过T, 问k最小是多少. 题解:先二分k,然后在k给 ...
- Python输出内容的三种方式:print输出 python脚本执行 linux直接执行
1. 在linux中安装python后,在linux命令行中输入python即可切换到Python命令行下 退出python命令行的命令: 老版本:ctrl+D 新版本:quit();或exit() ...
- 集合框架,ArrayList和Vector的区别,让arrayList线程安全的几种方案
boolean add(E e) 将指定的元素添加到此列表的尾部. void add(int index, E element) 将指定的元素插入此列表中的指定位置. boolean addAll(C ...
- input固定定位后,当input框获取到焦点时,会离开手机软键盘的解决方法
前些天做页面时候遇到这样一个问题,将input框用position:fixed固定定位在最底部的时候,当Input获取焦点的时候,input框离开了手机软键盘,而不是吸附在软键盘上,效果如下图: 找了 ...
- 盘点:崛起中的九大HTML5开发工具
HTML5被看做是Web开发者创建流行Web应用的利器,增加了对视频和Canvas 2D的支持.HTML5的诞生还让人们重新审视浏览器专用多媒体插件的未来,如Adobe的Flash和微软的Silver ...
- [转]Windows的窗口刷新机制
1.Windows的窗口刷新管理 窗口句柄(HWND)都是由操作系统内核管理的,系统内部有一个z-order序列,记录着当前窗口从屏幕底部(假象的从屏幕到眼睛的方向),到屏幕最高层的一个窗口句柄的排序 ...
- Linux 常用
1,解决ssh登录慢的问题记录 vim /etc/ssh/ssh_config # GSSAPIAuthentication no 把下面这一行的注释去掉 2,Linux查看当前是什么系统 ...
- get( )与getline( )区别
get与getline区别不是很大,但一个明显的区别是get遇到 '\n '字符后便返回,这是 '\n '还在缓冲区中,所以下次读出来的将是 '\n ',而getline遇到 '\n '也返回,但它会 ...
- ubuntu 添加源
edit file : /etc/apt/sources.list add: deb http://mirrors.163.com/ubuntu/ intrepid main restricted ...
- SharePoint 2013 开发——发布SharePoint应用程序
博客地址:http://blog.csdn.net/FoxDave 前几篇我们介绍了开发.部署和调试SharePoint应用程序的基础,本篇介绍更实用的操作,当我们开发一个SharePoint应用 ...