复习 | 重温jQuery和Zepto的API

2021-02-10 03:20

阅读:497

  jq和zepto很相似有许多共同的api,zepto也出了很多与jq不一样的api,总的来说,两者更相似,但是zepto更轻量一点,正好公司也在用,复习这两个没错

  jq中的zepto的事件和ajax我没有整理,因为之前有专门的文章去详细的写了ajax和事件绑定的区别

  再学ajax--第一天

  再学ajax--第二天 | 基于php+mysql+ajax的表单注册、登录、注销

  JS进阶 | 分析JS中的异步操作

  面试 | 蚂蚁金服面试经历 也讲到了js中的绑定事件的区别bind、on、delegate,以及事件绑定 事件委托的区别等

  jquery复习

 

DOCTYPE html>
html lang="en">
head>
  meta charset="UTF-8">
  meta name="viewport" content="width=device-width, initial-scale=1.0">
  meta http-equiv="X-UA-Compatible" content="ie=edge">
  title>Documenttitle>
head>
style >
  *{
    margin:0;
    padding: 0;
  }
style>
script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js">script>
script>
  /* jQuery([selector,[context]]) */
  console.log($(div>p));
  $(document.body).css("background","black");
  // 在文档的第一个表单中,查找所有的单选按钮
  console.log($(input:radio,document.forms[0]))
  /*jQuery(html,[ownerDocument])*/
  $(function(){
    $(
hello world
).appendTo(.test); // 动态创建一个 div 元素(以及其中的所有内容),并将它追加到 body 元素中 $(
,{ "class":"test_valid", text:"click me", click:function(){ $(this).toggleClass("test2"); } }).appendTo(".test") // 创建一个 元素,同时设定 type 属性、属性值,以及一些事件。 $(,{ type:text, val:"text", focusin:function(){ // alert("focusin"); }, focusout:function(){ // alert("focusout"); } }).appendTo(".test"); }) /* jQuery(callback)*/ $(function(){ // do something // 等价于$(document).ready() }) /* jQuery.holdReady(hold) */ // 延迟就绪事件,直到已加载的插件。 // $.holdReady(true); // $.getScript("plugin.js",function(){ // $.holdReady(false) // }) /* each(callback) */ $(function(){ $(.test > span).each(function(i){ // console.log(this); // console.log($(this)); this.innerHTML="span"+i; // $(this).toggleClass("span"+i); // $(this).text("hello"); // 跳出遍历 // return false; }) }) /* size() */ // jQuery 对象中元素的个数 console.log($("div").size()); console.log($(div).length); /* selector、context 、get([index]) 、index([selector|element]) */ $(function(){ $("ul") // 返回传给jQuery()的原始选择器 .append("
  • "+$(ul).selector+"") // 返回传给jQuery()的原始的DOM节点内容,即jQuery()的第二个参数。那么context指向当前的文档(document)。 console.log($(ul).context) console.log($(ul,document.body).context) console.log($(.innerTest>span).get(0)); // 选择文档中所有图像作为元素数组,并用数组内建的 reverse 方法将数组反向。 console.log($(.innerTest>span).get().reverse()); //传递一个DOM对象,返回这个对象在原先集合中的索引位置 console.log($(.innerTest>span).index(document.getElementById(bar))); //传递一个jQuery对象 console.log($(.innerTest>span).index($(#bar))); //传递一组jQuery对象,返回这个对象中第一个元素在原先集合中的索引位置 console.log($(.innerTest>span).index($(.innerTest>span:nth-child(2)))); }) /*数据缓存data*/ $(function(){ // 没什么卵用 $(.data).data("div-data","data"); }) /*queue(element,[queueName])*/ $(function(){ $("#show").on(click,function(){ var n = $(".queue").queue("fx"); // 显示在匹配元素上执行的函数队列的个数 console.log(n.length); }) function resuIt(){ $(.queue).show("slow"); $(.queue).animate({left:"+=200"},2000); $(.queue).slideToggle(1000); } resuIt() }) /*queue(element,[queueName]) jQuery.extend(object)*/ $(function(){ // 给选择器提供新方法 jQuery.fn.extend({ check:function(){ return this.each(function(){this.checked=true}) }, uncheck:function(){ return this.each(function(){this.checked=false}) } }) // 扩展jQuery对象本身 jQuery.extend({ min:function(a,b){return ab?a:b}, max:function(a,b){return a>b?a:b} }) $(".innerTest>input[type=checkbox]").check(); $(".innerTest>input[type=radio]").uncheck(); console.log(jQuery.min(1,2)); console.log(jQuery.max(3,4)); }) /*属性相关*/ $(function(){ // attr console.log($(.innerTest>input).eq(1).attr(type)) $(.innerTest>span).eq(2).attr({class:"innerSpan","data-span":"innerSpan"}) // class的值为innerHTML的值 $(.innerTest>span).eq(2).attr("class",function(){return this.innerHTML}) // removeAttr $(.innerTest>span).eq(0).removeAttr("class"); // prop 获取在匹配的元素集中的第一个元素的属性值。 console.log($(".innerTest>input[type=‘checkbox").prop(checked)); // 禁用所有checkbox $(".innerTest>input[type=‘checkbox‘]").prop(checked,function(i,val){ return !val; }) // addClass $(".innerTest>span:nth-child(5)").addClass("span5 span_5") // 加上不同的class $(".innerTest>span").addClass(function(){ return "span_"+$(this).index(); }) // removeClass $(".innerTest>span").eq(0).removeClass(span_0); // 删除最后一个元素与上面重复的class $(".innerTest>span:last").removeClass(function(){ return $(this).prev().attr(class); }) // toggleClass 如果存在(不存在)就删除(添加)一个类。 // 点击三下添加一个类 let count = 1; $(.innerTest>span).eq(5).on(click,function(){ $(this).toggleClass("highlight",count ++ % 3==0) }) // 根据父元素添加类 $(.innerTest>span).eq(5).toggleClass(function(){ if($(this).parent().is(".innerTest")){ return "span_6" } }) // html和text $(".innerTest>p").html(function(n){ $(this).text(n); // 下面两者等价 $(this).each(function(i){ console.log($(this)[i].innerHTML) }); console.log($(this).text()) }) // val 元素必须要有value $(.innerTest>input).eq(0).val(function(){ return $(this).val() + "..."; }) }) /*css相关*/ $(function(){ // css $(".innerTest>span").eq(0).css({font-size:24px,color:red}) // 点击时自动变大,用到了定时器的this指向,采用闭包解决 $(.innerTest>span).eq(1).on(click,function(){ let count = 1.2; var _this = $(this); setInterval(function(){ count++; _this.css({ font-size:parseFloat(15)*count +px }) },500) }); // offset 获取匹配元素在当前视口的相对偏移。 let offset_1 = $(.innerTest>span).eq(0).offset(); console.log(offset_1.left); console.log(offset_1.top); // position 获取匹配元素相对父元素的偏移。 let offset_2 = $(.innerTest>span).eq(0).position(); console.log(offset_2.left); console.log(offset_2.top); // scrollTop获取匹配元素相对滚动条顶部的偏移。 console.log($(.innerTest>span).eq(0).scrollTop()); // scrollLeft获取匹配元素相对滚动条左侧的偏移。 console.log($(.innerTest>span).eq(0).scrollLeft()); // height.width console.log($(.innerTest>span).eq(0).height()); console.log($(.innerTest>span).eq(0).width()); // innerHeight、innerWidth获取第一个匹配元素内部区域高度(包括补白、不包括边框)。 console.log($(.innerTest>span).eq(0).innerHeight()); console.log($(.innerTest>span).eq(0).innerWidth()); // outerHeight、outerWidth获取第一个匹配元素外部高度(默认包括补白和边框)。 console.log($(.innerTest>span).eq(0).outerHeight()); console.log($(.innerTest>span).eq(0).outerWidth()); }) /*选择器相关(就不写基本的或者简单的选择器了)*/ $(function(){ // 空格:在给定的祖先元素下匹配所有的后代元素 // >:在给定的父元素下匹配所有的子元素 // +:一个有效选择器并且紧接着第一个选择器 // ~ : 匹配元素之后的所有兄弟元素 // :first :获取第一个元素 // :last :获取最后一个元素 // :not(selector) :反向选择器 // :even :匹配所有索引值为偶数的元素,从 0 开始计数 // :odd :匹配所有索引值为奇数的元素,从 0 开始计数 // :eq(index) :匹配一个给定索引值的元素 // :gt(index) :匹配所有大于给定索引值的元素 // :lt(index) :匹配所有小于给定索引值的元素 // :header :匹配如 h1, h2, h3之类的标题元素 // :animated :匹配所有正在执行动画效果的元素 // :contain(text) : 匹配包含给定文本的元素 // :empty() : 匹配所有不包含子元素或者文本的空元素 // :has(selector) : 匹配含有选择器所匹配的元素的元素 console.log($(.data:has(p)).text()) // :parent() : 匹配含有子元素或者文本的元素 // :hidden 匹配所有不可见元素,或者type为hidden的元素 console.log($(.innerTest>h1:hidden)) // :visible 匹配所有的可见元素 // [attribute] 匹配包含给定属性的元素。 console.log($(div[class])) // [attribute=value] console.log($("input[type=‘button‘]")) // [attribute!=value] 匹配所有不含有指定的属性,或者属性不等于特定值的元素。 console.log($("input[type!=‘button‘]")) // [attribute^=value] 匹配给定的属性是以某些值开始的元素 console.log($("span[class^=‘span‘]")) // [attribute$=value] 匹配给定的属性是以某些值结尾的元素 console.log($("span[class$=‘_2‘]")) // [attribute*=value] 匹配给定的属性是以包含某些值的元素 console.log($("span[class*=‘_‘]")) // [selector1][selector2][selectorN] 复合属性选择器,需要同时满足多个条件时使用。 console.log($("input[class][name=‘radio‘]")) // :first-child 匹配第一个子元素 注意和+号的区别 console.log($(ul li:first-child)) // ‘:last‘只匹配一个元素,而此选择符将为每个父元素匹配一个子元素 console.log($(ul li:last-child)) }) /*文档处理*/ // appendTo:把选择器的内容追加到appendTo里面的内容中和append:把append里面的内容追加到选择器中 // prepend(content):向每个匹配的元素内部前置内容。 $(function(){ // after(content|fn) // before(content|fn) console.log($("p:nth-child(1)").after("hello")) console.log($("p:nth-child(1)").before("hello")) // insertAfter(content) 前者插到后者后面 $(".123").insertAfter(".456"); // insertBefore(content) 后者插到前者前面 $(".101112").insertBefore(".789"); // wrap(html|ele|fn) 把所有匹配的元素用其他元素的结构化标记包裹起来。 $("b:nth-child(1)").wrap("
    ") // replaceWith(content|fn) $(".replaceP").replaceWith("replaceP") // empty() 删除匹配的元素集合中所有的子节点。 $(".emptyAll").empty() // remove([expr]) 从DOM中删除所有匹配的元素 $(".remove").remove(); // filter $(".filter").filter(function(idx){ console.log($(this)); return $("ol",this).length==0; }) // is(expr|obj|ele|fn) console.log($(".innerTest2").is("div")); // find(expr|obj|ele|fn) console.log($(".innerTest2").find("li")) // add() 返回一个数组,包含添加过的元素 console.log($(".innerTest2").add("

    ---

    ")); }) /* 动画 */ $(function(){ // show $(".innerTest2 li").eq(0).show("slow"); // hide $(".innerTest2 li").eq(1).hide("slow"); $(".innerTest2 li").eq(2).slideDown("slow"); $(".innerTest2 li").eq(2).fadeOut("slow"); $(".innerTest2 li").eq(2).fadeIn("slow"); }) script> body> div class="test" style="width:500px;heigth:500px;border:solid 1px black"> h1>测试区h1> p>div>pp> input type="text"> br> span>span> span>span> ul>ul> ul class="ul"> li>-li> li>+li> ul> div class="innerTest"> h1 style="display:none">h1h1> a href="">a> span id="foo" class="span1" style="border:solid 1px black">1span> span id="bar">2span> span>3span> span class="span4">4span> span class="span4">5span> span>6span> input type="checkbox" value="checkbox1">input type="radio" name="radio" class="radio">input type="checkbox">input type="checkbox">p>p> p>p> p>p> div> p class="filter"> ol> li>helloli> ol> p> div class="innerTest2" > li style="display:none">1li> li>2li> li>3li> div> p class="replaceP">replacePp> p class="emptyAll">empty b>123b> p class="remove">empty b>123b> p class="123">123p>div class="pdiv">456div> p class="123">789p>div class="101112">101112div> div class="data">p>有pp>div> input type="button" id="show" value="show"> div class="queue">queuequeuequeuediv> div> form action=""> input type="radio" value="input:radio"> form> body> html>
  •  

      zepto

    DOCTYPE html>
    html lang="en">
    head>
      meta charset="UTF-8">
      meta name="viewport" content="width=device-width, initial-scale=1.0">
      meta http-equiv="X-UA-Compatible" content="ie=edge">
      title>Documenttitle>
    head>
    script src="http://apps.bdimg.com/libs/zepto/1.1.4/zepto.js">script>
    script type="text/javascript">
      $(function(){
        // 1、驼峰转换
        console.log($.camelCase("hello-world"))
        // 2、检查父节点是否包含给定的dom节点,如果两者相同,则返回 false。
        // $.contains = function (parent, node) {
        //  return parent !== node && parent.contains(node)
        // }
        // true
        console.log($.contains($(".parent")[0],$(".child")[0]))
        // false
        console.log($.contains($("body")[0],$("body")[0]))
        // false
        console.log($.contains($(".parent")[0],$(".parent")[0]))
        // 3、each
        $.each([a,b,c],function(index,item){
          // 索引
          console.log(index);
          // 内容
          console.log(item);
        })
        var obj = {name:"zepto","size":"micro"};
        $.each(obj,function(key,value){
          console.log(key);
          console.log(value);
        })
        // 4、$.extend
        var target = {"1":"2"}
        var source = {"name":"zepto"}
        $.extend(target,source);
        console.log(target)
        // 5、$.fn
        $.fn.alert1 = function(){
          alert(1);
        }
        $(".parent").alert1();
        // 6、$.grep
        console.log($.grep([1,2,3],function(item){
          return item >1
        }))
        // 7、$.inArray 搜索数组中指定值并返回它的索引(如果没有找到则返回-1)。
        console.log($.inArray("abc",["abc","123"]))
        console.log($.inArray("abc",["123"]))
        // 8、$.isArray 如果object是array,则返回ture。
        // 9、$.isFunction  如果object是function,则返回ture.
        // 10、$.isPlainObject 测试对象是否是纯粹的对象(通过 "{}" 或者 "new Object" 创建的),如果是,则返回true。
        console.log($.isPlainObject(window)); //false
        console.log($.isPlainObject({}));  //true
        // 11、$.isWindow 确定参数是否为一个窗口(window对象),如果是则返回true。 这在处理iframe时非常有用,因为每个iframe都有它们自己的window对象
        // 12、$.map


    评论


    亲,登录后才可以留言!