jQuery语法和常用函数总结

jQ对象是对DOM对象进行包装后产生的对象,DOM对象和jQ对象中的方法和属性不可互用
jQuery对象与DOM对象可相互转换,因此,可约定好定义变量的风格;
var $variable = jQ对象;
var variable = DOM对象;
相互转换:

//jQ对象转DOM对象
var variable = $variable[0];//数组方法
var variable = $variable.get(0);//jQuery中的get(index)方法
//DOM对象转jQ对象
var $variable = $(variable);

$()函数就是一个jQuery对象的制造工厂

jQ选择器

  • 基本选择器
  • 层次选择器
  • 过滤选择器
    1.基本过滤
    2.内容过滤
    3.可见性过滤
    4.属性过滤
    5.子元素过滤
    6.表单对象属性过滤

e.q. $(".side-nav>ul")

jQ DOM操作

DOM Core并不专属于JavaScript,任何一种支持DOM的程序设计语言都可以使用它。——《锋利的jQuery》

DOM Core
getElementById();getElementsByTagName();getAttribute();setAttribute();
HTML-DOM(出现比DOM Core还要早)
document.forms;element.src;
CSS DOM
element.style.color = "red";

  • 查找结点
    1.结点元素
    $("ul li:eq(1)");
    2.结点属性
    $para.attr("title");
  • 创建结点
    1.$()函数
    $("<li title="text">text</li>");
  • 插入结点
    1.append();
    $("p").append("<b>123</b>");//在元素内部最后追加<b>123</b>
    2.prepend();
    //元素内部前置内容
    3.after();
    $("p").after("<b>123</b>");//指定元素之后插入内容
    4.before();
    //指定元素之前插入内容
  • 删除结点
    1.remove();
    $("ul li").remove("li[titile!=text]");
    2.detach();
    //不会把匹配元素从jQ对象中删除,绑定的事件和附加的数据都会保留下来
    3.empty();
    //清空结点,即清空元素后代结点,元素里的内容
  • 复制结点
    1.clone();
    $("li").clone(true).append($("ul"));//复制的结点只有加上true参数才具有相应行为
  • 替换节点
    1.replaceWith();
    $("p").replaceWith("<b>123</b>");//替换
  • 包裹结点
    1.wrap();
    $("p").wrap("<b>123</b>");//用b元素将p元素包裹起来,单独包裹
    2.wrapAll();
    //统一包裹,若多个元素之间有其他元素,将放到包裹元素之后
    3.wrapInner();
    //包裹其子内容
  • 结点属性操作
    1.获取属性
    attr()
    2.删除属性
    removeAttr()
  • 样式操作
    1.设置属性
    $("p").attr("class","high")//属性设置会覆盖原有class;
    2.addClass();
    $("p").addClass("another");//addClass()不会覆盖原有class
    3.removeClass("high another");
    //参数可删除一个或多个class,无参数则删除所有样式
    4.toggleClass();toggle();
    $("p").toggleClass("another")//切换样式,重复添加和删除
    $btn.toggle(function(){ //显示元素 }.function(){ //隐藏元素})
    5.hasClass();
    //等价于is()方法,返回true或false
  • 获取HTML,文本和值
    1.html();
    //类似于innerHTML属性
    2.text();
    //类似于innerText属性
    3.val();
    //类似于value属性
  • 遍历结点
    1.children("");
    var $ul = $("ul").children();//children()只考虑子元素不考虑子元素的后代元素,参数进行筛选
    2.next();
    //元素后紧邻的同辈元素
    3.prev();
    //元素前紧邻的同辈元素
    4.siblings();
    //匹配元素前后所有同辈元素
    5.parent(''para");parents("para");closest("para")
    //parent()从直接父级结点查找并返回一个父级元素
    //parents()从从直接父级节点查找并返回多个祖先元素
    //closest()从自身结点查找并返回第一个匹配元素
  • CSS-DOM操作
    1.css();
    css("height");//获取单个属性值
    css("backgroundColor","#fff");//设置单个属性值(驼峰命名法)
    css({"fontSize":"30px","color":"red"});//设置多个属性值
    css()中获得的高度宽度也是字符串
    2.height(),width();
    $("div").height()//获取
    $("div").height(100);//设置100px
    $("div").height(2em);//设置为2em
    3.offset();
    //获取当前元素相对于视窗的偏移量,其对象包含left,top两个属性
    4.position();
    //获取当前元素相对于最近的一个position属性设置为relative或absolute的祖父节点的相对偏移
    5.scrollTop();scrollLeft();
    //获取当前元素滚动条相距顶端/左端的距离

jQ 事件

事件冒泡:嵌套元素中都绑定了事件,事件触发从最里层至最外层
event.stopPropagation()//阻止事件冒泡
event.preventDefault()//阻止事件默认行为
event.target//触发事件的元素

  • 加载DOM
    1.$(document).ready(function(){});$(function(){});$().ready(function(){});
    //window.onload需要加载网页中所有元素,而$(document).ready()在DOM完全就绪时就可以调用
    //window.onload只能保存对一个函数的引用,$(document).ready()可以多次调用
    2.事件绑定
    事件类型:blur,focus,load,resize,scroll,unload,click,dbclick,mousedown,mouseup,mouseover,mouseout,mouseenter,mouseleave,change,select,submit,keypress,keyup,error
    bind(type,[data],fn);
var message = "text";
    $("button").bind("click dbclick",{msg:message},function(event){//event:事件对象
        $(this).show();//将事件主体DOM元素转换为jQ对象
        alert(event.data.msg)})//data参数可选(一般不用
//可绑定多个事件
$(function(){
        $("button").bind("mouseover",function(){
            $(this).next().show();  
        }).bind("mouseout",function(){
            $(this).next().hide();
        })
    })```
`one()函数同bind()相同,但只触发一次`
3.移除事件
unbind();
`//无参则删除所有绑定事件`
`//带一个参数则删除指定绑定事件`
`//两个参数则删除指定绑定事件的指定函数`
4.切换事件
1.hover(over,out);

$("a").hover(function(){
//code1
},function(){
//code2
})
//同mouseenter和mouseleave是等价的

2.toggle(fn,fn2,fn3,[...])
`//多个函数依次调用,一般用于2种状态切换`
5.模拟操作
trigger();
`$(#btn).trigger("click")//模拟单击操作`
6.自定义事件
###jQ动画
- show();hide();toggle()
`show()将display为none的元素设置为display样式为先前的显示状态(如block或inline)`
`hide()将display设置为none`
`参数为时间,show()和hide()同时改变元素的高度,宽度,不透明度`
- fadeIn();fadeOut;
`//只改变不透明度,直至display为none或先前状态`
- slideUp();slideDown();slideToggle();
`//只改变高度,直至display为none或先前状态`
- animate(params,[duration],[easing],[callback])

$("#btn").click(function(){
$(this).animate({left:"400px",height:"200px",opacity:"1"},3000)
.animate({top:"200px",width:"200px"},3000.function(){
$(this.css("border","5px solid blue"));
})
})
//综合动画,最后一步改变css样式:通过回调函数(否则动画刚开始就会改变css样式)

- stop();delay()
`//太多了,自己翻书吧`
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容