缓存变量:DOM遍历是昂贵的,所以尽量将会重用的元素缓存。

$element = $('#element');
h = $element.height(); //缓存
$element.css('height',h-20);

如果你打算对DOM元素做大量操作(连续设置多个属性或css样式),建议首先分离元素然后在添加。

使用var与匈牙利命名法,且避免全局变量 ;  

优化选择符;避免多个ID选择符

ajax:

  • 使用相关函数:

    $("#file").on("click","button",function() {
    $.ajax("confirmation.html",{
    data: {"confNum":1234},
    success: function(res) {},
    error: function(req,errorType,errorMessage) {},
    timeout:3000,
    beforeSend: function() {
    $(".confirmation").addClass('is-loading');
    },
    complete: function() {
    $(".confirmation").removeClass("is-loading");
    }
    })
    });
  • 提交表单:
    $("form").on("submit",function(event) {
    event.preventDefault(); //submit will reflash the page
    var form = $(this);
    $.ajax("/book", {
    type: "POST",
    data: form.serialize(), //use this;
    success: function(result) {
    form.remove();
    $("#vacation").hide().html(result).fadeIn();
    }
    });
    });
  • 优化操作:
    $.ajax('/test.html')
    .done(function(res) {console.log(res,'done1');})
    .fail(function(res) {console.log(res,'fail');})
  • 要多个ajax共同使用的时候
    $.when($.ajax("test1.html"),$.ajax("test2.html"))
    .done(function(res) {console.log(res,'done');})
    .fail(function(res) {console.log(res,'fail');}); //都成功才会执行done;返回第一个ajax的res;

写插件:

  • html:

    <div class="container">
    <div class="col-sm-12 top">
    <button id="all" class="btn btn-primary col-sm-offset-10 show-price">show all</button>
    </div>
    <div class="jumbotron col-sm-3 vacation" data-price="110">
    <h4>Hawaiian Vaction</h4>
    <button class="click btn btn-info">SHOE PRICE</button>
    <p class="no-hide"><a href="#" class="remove-vacation">no thanks!</a></p>
    </div> <div class="jumbotron col-sm-3 col-sm-offset-1 vacation" data-price="150">
    <h4>European Getaway</h4>
    <button class="click btn btn-info">SHOE PRICE</button>
    <p class="no-hide"><a href="#" class="remove-vacation">no thanks!</a></p>
    </div> <div class="jumbotron col-sm-3 col-sm-offset-1 vacation" data-price="90">
    <h4>Visit Japan</h4>
    <button class="click btn btn-info">SHOE PRICE</button>
    <p class="no-hide"><a href="#" class="remove-vacation">no thanks!</a></p>
    </div>
    </div>
  • js:
    $.fn.pricefy = function(options) {
    this.each(function() {
    //使用$.extend添加属性;setting为要操作的数据集合
    var settings = $.extend({
    days: 3,
    vacation: $(this),
    price: $(this).data("price")
    },options);
    var show = function() {
    var details = $("<p>Book" + settings.days +"days for $" + (settings.days * settings.price)+ "</p>");
    settings.vacation.find(".click").hide();
    settings.vacation.append(details);
    };
    var remove = function() {
    settings.vacation.hide().off(".pricefy");
    };
    settings.vacation.on("click.pricefy","button",show);
    settings.vacation.on("show.pricefy",show);
    settings.vacation.on("click.pricefy",".remove-vacation",remove);
    })
    }; $(function() {
    $(".vacation").pricefy();
    $(".show-price").on("click",function(event) {
    event.preventDefault();
    $(".vacation").trigger('show.pricefy');
    });
    });

      

      

  

jquery优化02的更多相关文章

  1. 新手必看的jQuery优化笔记十则

    jQuery优化 1.简介 jQuery正在成为Web开发人员首选的JavaScript库,作为Web开发者,除了要了解语言和框架的应用技巧外,如何提升语言本身的性能也是开发人员应该思考的问题.文章就 ...

  2. jquery优化引发的思考

    无意间看到jquery优化的一个细节让我觉得不可思议记录一下.仅仅只是换个地方代码就能提高数倍的效率,带给我的不是个仅是个小技巧,而是一总编程思想,技术大牛往往是在细节上体现. 通过缓存最小化选择操作 ...

  3. jquery优化28个建议

    我一直在寻找有关jQuery性能优化方面的小窍门,能让我那臃肿的动态网页应用变得轻便些.找了很多文章后,我决定将最好最常用的一些优化性能的建议列出来.我也做了一个jQuery性能优化的简明样式表,你可 ...

  4. jquery优化轮播图2

    继续优化 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF- ...

  5. jquery优化

    选择器优化执行的速度 选择器 优先:id>元素>类 使用对象缓存:即使用变量来保存对象名,var $myDiv = $("#myDiv"):$myDiv.show(); ...

  6. jQuery优化性能的十种方法

    1,总是从ID选择器开始继承 例如: <div id="content"> <form method="post" action=" ...

  7. ☀【jQuery 优化】jQuery基础教程(第3版)

    jQuery代码优化:选择符篇 √ http://www.ituring.com.cn/article/377 jQuery代码优化:遍历篇 √ http://www.ituring.com.cn/a ...

  8. jQuery 学习02——效果:隐藏/显示、淡入淡出、滑动、动画、停止动画、Callback、链

    jQuery 效果- 隐藏hide()和显示show() 语法: $(selector).hide(speed,callback);$(selector).show(speed,callback); ...

  9. jQuery总结02

    1 如何搭建一个 jQuery 环境? 2 jQuery 对象与 DOM 对象一样吗?区别是什么? 3 jQuery选择器类型有哪些?

随机推荐

  1. 移动端Web开发注意点

    不用考虑浏览器兼容性 移动端开发主要对象是手持设备,其中绝大部分是IOS和Android系统,so,在开发此类页面时不必纠结IE和其他一些2B浏览器的兼容性,webkit是本次开发重点. 当然,不同版 ...

  2. Linux下的网络管理工具—OpenNMS

    导读 OpenNMS的是一个运营商级别的,高度集成的,开放源码的平台,用于构建网络监控解决方案.OpenNMS有两个发行版:Meridian and Horizon.使用Meridian是可取的,对企 ...

  3. Stanford机器学习---第六讲. 怎样选择机器学习方法、系统

    原文:http://blog.csdn.net/abcjennifer/article/details/7797502 本栏目(Machine learning)包括单参数的线性回归.多参数的线性回归 ...

  4. [另开新坑] 算导v3 #26 最大流 翻译

    26 最大流 就像我们可以对一个路网构建一个有向图求最短路一样,我们也可以将一个有向图看成是一个"流量网络(flow network)",用它来回答关于流的问题. Just as ...

  5. 二模Day2题解

    小明搬家 题目描述 小明要搬家了,大家都来帮忙. 小明现在住在第N楼,总共K个人要把X个大箱子搬上N楼. 最开始X个箱子都在1楼,但是经过一段混乱的搬运已经乱掉了.最后大家发现这样混乱地搬运过程效率太 ...

  6. MySQL查询测试经验

    测试表geoinfo,整个表超过1100万行,表结构: CREATE TABLE `geoinfo` ( `objectid` ) NOT NULL AUTO_INCREMENT , `latitud ...

  7. 【OpenStack】OpenStack系列9之Compute节点安装

    安装 安装参考: https://github.com/yongluo2013/osf-openstack-training/blob/master/installation/openstack-ic ...

  8. eclipse字体的设置

    eclipse的默认字体太小,所以设置的大一些比较清楚,方法很简单,单击菜单栏的"Window"选择"Preferences",如下图: 然后左侧依次选择Gen ...

  9. IOS多线程(GCD)

    简介 Grand Central Dispatch 简称(GCD)是苹果公司开发的技术,以优化的应用程序支持多核心处理器和其他的对称多处理系统的系统.这建立在任务并行执行的线程池模式的基础上的.它首次 ...

  10. Struts文件上传allowedTypes问题,烦人的“允许上传的文件类型”

    Struts的文件上传问题,相信很多人都会使用allowedTypes参数来配置允许上传的文件类型,如下. <param name="allowedTypes"> im ...