jquery基础知识学习笔记

jquery是一个js库/常用版本是jjquery-1.7.2.js/这个版本主要是用来做开放用途
做产品的时候是用它的min版本。玩jquery的时候,不管干啥都要花钱(美元)
 

注意点:
1.silbings('input');除了发生事件的那个元素的其他同级input兄弟元素 注意silblings要加上s
 
2.jquery无法获取当前时间
 
3.jquery对象和js对象混合操作的问题(阅读书籍解决)
 
4.innerHTML=html(内容);
 
5.is(":checked")是jq的方法判断元素是否被选择,返回布尔值
   
6.jq没有定时器,只能写原生
 
7.bind是绑定事件unbind是的解除绑定事件,一般上都是用不上的,因为,jq默认所有的事件都是绑定的状态,一般都用on代替的,因为on有事件委托的功能
 
8.parent()查找结构父级元素     offsetParent()定位父级
 
9.css('',value)一定要加引号
 
10.$('img').size();计算文档中所有图片的数量
 
11.一个元素绑定多个事件和多个函数
 $('#div1').on({'mouseover':function(){
 
        },'mousemove':function(){
 
       }});
 
12.清空一个事件用off();
 
13.jquery的阻止默认事件的方法
     return false               
     ev.preventDefault()
 
14.$(this).find('span')     找到this下面的span

 
.click(fn);
.mouseover(fn);
.mouseout(fn);
.hover(fn1,fn2);
.toggle(fn1,fn2,fn3.....);
效果:
.hide();     隐藏
.show();     显示
.animate({name:value,name:value});
**前面必须加上stop()
 

非常重要的:jquery和DOM对象的转换
        原生对象-》jquery对象         
obj==>$(obj)
jquery对象-》原生对象
$('div')[下标]
$().get(下标)

jquery中的循环:
     jquery的循环
$('div').each(function(index,element){
    index             下标
    element         每个原生对象
    this                每个原生对象
});
事件里面this         原生
each里面this         原生
jquery中所有的this都是原生的。
但是有唯一的例外,插件中的this是jquery对象

插件
1.
$.fn.函数名=function(){};
2.
$.fn.extend({
    函数name1:function(){},
    函数name2:function(){},
    函数name3:function(){}
});
例子:
'use strict'
$.fn.extend({
    cs:function(sName,sValue){
     //插件中的this是jquery对象
        this.css(sName,sValue);
    }
});

★号是目前已经确定比较重要的知识点
页面载入:用第一种是公司必须用的请记住
     1.$(document).ready.$(function(){});     这是主流常用的
     2.$(function(){});
索引值:
     $('div').eq($(this).index())
选择器:主要核心是和css的选择器相同
     ==元素选择==
  $('#id')                 id选择器
  $('.class')                  class选择器
$('tagName')    标签选择器
     ==层级选择==
  $("div,span,p.myClass")     和选择
$('#box ol .active input'); 层级选择器(找到什么下面的什么元素)
     ==同级选择==
$("form > input")    匹配form中所有的子级input元素。
$("label + input")    匹配所有跟在 label 后面的 input 元素
$("form ~ input")    找到所有与表单同级的 input 元素
==伪类选择==
$("li:eq(index)")    index是下标
$('li:first');    获取匹配的第一个元素
$('li:last');     获取匹配的最后一个元素
$("input:not(:checked)")    查找所有未选中的 input 元素
$("li:even")    选择奇数行
$('li:odd')        选择偶数行
$(":header").css("background", "#EEE");    给页面内所有标题加上背景色
$("#login:focus");    页面加载后id为login 的设置焦点
$("div:has(p)").addClass("test");    给所有包含 p 元素的 div 元素添加一个 text 类
==属性选择器==
$("input[name='newsletter']").attr("checked", true);查找所有 name 属性是 newsletter 的 input 元素

操作css
.css(name);                                        获取
.css(name,value);                               修改一个
.css({name:value,name:value});         批量修改
 

 
 
操作属性
.attr(name);                                     获取
.attr(name,value);                           修改一个
.attr({name:value,name:value});      批量修改
$("img").removeAttr("src");          要删除的属性名
禁用和选中所有页面上的复选框。
$("input[type='checkbox']").prop("disabled", false);
$("input[type='checkbox']").prop("checked", true);
操作class
.addClass()
.removeClass()
        $("p").removeClass("selected");从匹配的元素中删除 'selected' 类

操作内容
表单元素(相当于是value)
.val()         获取
.val('a')     设置
.val('')       清空
非表单元素(相当于innerHTML)
.html()        获取
.html('a')    设置
.html('')      清空

DOM操作:
创建元素:
     $('<div>创建了一个div标签</div>')
2.插入元素
    appendTo         内部后面
     $('<div><strong>abc</strong></div>').appendTo($('div'));
    prependTo        内部前面
    insertAfter        外部后面
    insertBefore      外部前面
3.删除元素
        $().remove();
        $("p").detach();从DOM中把所有段落删除
4.获取父节点
$().parent();             找结构父级
$().offsetParent();     找定位父级
5.克隆
     $("b").clone().prependTo("p");克隆所有b元素(并选中这些克隆的副本),然后将它们前置到所有段落中
 
6.获取位置                 js                   jquery
定位父级位置             offset             position注意,要定位
绝对位置                  getPos             offset     绝对位置
 
7.获取尺寸
width()/height()                           单纯的宽高
innerWidth()/innerHeight()         宽高+padding
outerWidth()/outerHeight()         盒子模型的宽高

事件ev:jquery中的ev已经是兼容后的
事件绑定
*jquery中所有的事件都是默认绑定上去的。
bind     事件都是绑定好的所以用处不大
unbind
事件委托:
     on('事件名',fn)委托绑定事件
     off('事件名',fn)取消绑定委托事件
posted @ 2016-11-27 12:55  sweeeper  阅读(414)  评论(0编辑  收藏  举报