位置: 编程技术 - 正文

15个值得开发人员关注的jQuery开发技巧和心得总结【经典收藏】(15个值得开发人是谁)

编辑:rootadmin

推荐整理分享15个值得开发人员关注的jQuery开发技巧和心得总结【经典收藏】(15个值得开发人是谁),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:做开发的,15个值得开发人是谁,值得开发的项目,谁能开发人员中要求最高的是,做开发的,值得开发的项目,15个值得开发人是谁,15个值得开发人物,内容如对您有帮助,希望把文章链接给更多的朋友!

本文总结述了个值得开发人员关注的jQuery开发技巧和心得。非常精辟实用!分享给大家供大家参考,具体如下:

在这篇文章中,我们将介绍个让你的jQuery更加有效的技巧,大部分关于性能提升的,希望大家能够喜欢!

1. 尽量使用最新版本的jQuery类库

jQuery项目中使用了大量的创新。最好的方法来提高性能就是使用最新版本的jQuery。每一个新的版本都包含了优化的bug修复。对我们来说唯一要干的就是修改tag,何乐而不为呢?我们也可以使用免费的CDN服务,例如, Google来存放jQuery类库。

2. 使用简单的选择器

直到最近,返回DOM元素的方式都是解析选择器字符串,JavaScript循环和内建的javascript API,例如, getElementbyId(),getElementsByTagName(),getElementsByClassName()三种方式的整合使用。但是现代浏览器都开始支持querySelectorAll(),这个方法能够理解CSS查询器,而且能带来显著的性能提升。

然而,我们应该避免使用复杂的选择器返回元素。更不用说很多用户使用老版本的浏览器,强迫jQuery去处理DOM树。这个方式非常慢。

选择id是最快速的方式。如果你需要使用class名称, 那么你最好带上tag名称,这样会更快些。特别是在老浏览器和移动设备上。

访问DOM是javascript应用最慢的方式 ,因此尽量少使用。使用变量去保存选择器,这样会使用cache来保存。性能更好。

另外一个值得做的是jQuery给了你很多的额外便利选择器 ,例如,:visible,:hidden,:animated还有其它,这些不是合法的CSS3选择器。结果是你使用这些类库就不能有效地利用 querySelectorAll() 方法。为了弥补这个问题,你需要先选择元素,再过滤,如下:

3. 数组方式使用jQuery对象

运行选择器的结果是一个jQuery对象。然而,jQuery类库让你感觉你正在使用一个定义了index和长度的数组。

如果性能是你关注的,那么使用简单for或者while循环来处理,而不是$.each(),这样能使你的代码更快。

检查长度也是一个检查你的collection是否含有元素的方式。

4. 选择器属性

jQuery提供了一个属性,这个属性显示了用来做链式的选择器。

虽然上面的例子针对同样的元素,选择器则完全不一样。第二个实际上是非法的,你不可以使用它来创建一个对象。只能用来显示filter方法是用来缩小collection。

5. 创建一个空的jQuery对象

创建一个新的jQuery空间能极大的减小开销。有时候,你可能需要创建一个空的对象,然后使用add()方法添加对象。

这也是quickEach方法的基础,你可以使用这种更快的方式而非each()。

6. 选择一个随机元素

上面我提到过,jQuery添加它自己的选择器过滤。除了类库,你可以添加自己的过滤器。只需要添加一个新的方法到$.expr[':']对象。一个非常棒的使用方式是Waldek Mastykarz的博客中提到的:创建一个用来返回随机元素的选择器。你可以修改下面代码:

7. 使用CSS Hooks

CSS hooks API是提供开发人员得到和设置特定的CSS数值的方法。使用它,你可以隐藏浏览器特定的执行并且使用一个统一的界面来存取特定的属性。

更好的在于,人们已经创建了一个支持CSS hooks类库

8. 使用自定义的删除方法

15个值得开发人员关注的jQuery开发技巧和心得总结【经典收藏】(15个值得开发人是谁)

你可能听到过jQuery的删除插件,它能够允许你给你的动画添加特效。唯一的缺点是你的访问者需要加载另外一个javascript文件。幸运的是,你可以简单的从插件拷贝效果,并且添加到jQuery.easing对象中,如下:

9. $.proxy()

使用callback方法的缺点之一是当执行类库中的方法后,context被设置到另外一个元素,例如:

执行下面代码:

你将遇到问题,button会消失,不是panel。使用$.proxy方法,你可以这样书写代码:

这样才正确的执行。$.proxy方法接受两个参数,你最初的方法,还有context。这里阅读更多$.proxy in the docs.。

. 判断页面是否太过复杂

一个非常简单的道理,约复杂的页面,加载的速度越慢。你可以使用下面代码检查一下你的页面内容:

以上代码返回的数值越小,网页加载速度越快。你可以考虑通过删除无用多余的元素来优化你的代码

. 将你的代码转化成jQuery插件

如果你要花一定得时间去开发一段jQuery代码,那么你可以考虑将代码变成插件。这将能够帮助你重用代码,并且能够有效的帮助你组织代码。创建一个插件代码如下:

你可以在这里阅读更多开发教程。

. 设置全局AJAX为缺省

如果你开发ajax程序的话,你肯定需要有”加载中“之类的显示告知用户,ajax正在进行,我们可以使用如下代码统一管理,如下:

. 在动画中使用delay()方法

链式的动画效果是jQuery的强大之处。但是有一个忽略了的细节就是你可以在动画之间加上delays,如下:

jQuery动画帮了我们大忙,否则我们得自己处理一堆的细节,设置timtout,处理属性值,跟踪动画变化等等。

. 合理利用HTML5的Data属性

HTML5的data属性可以帮助我们插入数据。特别合适前后端的数据交换。jQuery近来发布的data()方法,可以有效的利用HTML5的属性,来自动得到数据。下面是个例子:

为了存取数据你需要调用如下代码:

如果你想看看实际的例子,请参考这篇教程:

HTML5+jQuery插件Quicksand实现超酷的星际争霸2兵种分类展示效果: 本地存储和jQuery

本地存储是一个超级简单的API。简单的添加你的数据到localStorage全局属性中:

localStorage.someData = "This is going to be saved across page refreshes and browser restarts";

但是对于老的浏览器来说,这个不是个好消息。因为他们不支持。但是我们可以使用jQuery的插件来提供支持一旦本地存储不能用的话。这种方式可以使得本地存储功能正常工作。

以上是我们介绍的个jQuery的开发技巧。希望本文所述对大家jQuery程序设计有所帮助。

更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jquery中Ajax用法总结》、《jQuery表格(table)操作技巧汇总》、《jQuery拖拽特效与技巧总结》、《jQuery扩展技巧总结》、《jQuery常见经典特效汇总》、《jQuery动画与特效用法总结》、《jquery选择器用法总结》及《jQuery常用插件及用法总结》

希望本文所述对大家jQuery程序设计有所帮助。

jquery easyui datagrid实现增加,修改,删除方法总结 本文实例讲述了jqueryeasyuidatagrid实现增加,修改,删除的方法。分享给大家供大家参考,具体如下:页面:bodyformid="form1"runat="server"tableid="tt"/table/form/body

jQuery中each()、find()和filter()等节点操作方法详解(推荐) 1.each(callback)官方解释:返回值:jQuery概述以每一个匹配的元素作为上下文来执行一个函数。意味着,每次执行传递进来的函数时,函数中的this关键字都

jQuery中的each()详细介绍(推荐) each()方法能使DOM循环结构简洁,不容易出错。each()函数封装了十分强大的遍历功能,使用也很方便,它可以遍历一维数组、多维数组、DOM,JSON等等在javaSc

标签: 15个值得开发人是谁

本文链接地址:https://www.jiuchutong.com/biancheng/387281.html 转载请保留说明!

上一篇:HTML5+jQuery插件Quicksand实现超酷的星际争霸2兵种分类展示效果(附demo源码下载)(jquery22插件网)

下一篇:jquery easyui datagrid实现增加,修改,删除方法总结

  • 小规模减免增值税
  • 职工教育经费8%怎么算
  • 企业所得税汇算清缴申报表
  • 境外投资子公司审计报告人民币汇率
  • 注销时其他应付款余额怎么账务处理
  • 外出拓展训练活动所花的费用怎么做分录?
  • 企业发票入账冲销流程
  • 设备维保费税率怎么算
  • 办税员身份怎么办理
  • 管理费用纳税调增账务处理
  • 免征残保金还需交税吗
  • 固定资产用于免税项目 进项税处理
  • 报关单和发票上的公司抬头不一致
  • 固定资产清理产生的费用
  • 为什么有的发票没有发票章
  • 机打发票验旧是什么意思
  • 有限合伙人的投资风险有哪些
  • 材料未到,货款尚未支付
  • 总账每个月都要结账吗
  • 合同成本如何设一级科目
  • 苹果电脑安装了windows能取消吗
  • 年末结转年初建账
  • 预计负债基本确定的概率区间
  • 制造费用的低值易耗品包括哪些内容
  • wordpress访问速度优化
  • 系统之家有没有官网
  • PHP函数func_num_args用法实例分析
  • php实现修改功能
  • 销售成本属于成本吗
  • 【2023亲测可用】JS 获取电脑本地IP 和 电脑网络IP(外网IP|公网IP)
  • 收到银行承兑汇票会计分录
  • phpcgi远程代码执行漏洞
  • 会计分录怎么分借方和贷方
  • 微信小程序中如何打开不加检验文件的网页
  • node.js deno
  • opencv怎么训练
  • smarty模板引擎
  • thinkphp6框架源码完整版下载
  • mysql中的语法
  • 个体户一年能开多少票不用交税
  • 公司没有收入怎么办
  • 法人一直把公户账户转账
  • 承兑汇票利息分录
  • 原材料暂估入库是什么意思
  • 暂估成本跨年后收到票如何处理,红冲按哪个金额冲
  • 不按规定纳税的违法行为
  • 人力公司开的代驾发票
  • 餐饮发票食品发票
  • 环保局检查锅炉房都查什么
  • 电子发票怎么截屏
  • 专家咨询费支付标准
  • 怎样计算存款利息?
  • 计算机二级考试报名入口官网
  • mysql中怎么修改数据
  • linux进入操作系统
  • thinkpad如何安装win10
  • 用U盘安装win11
  • linux的ftp命令
  • 如何用u盘安装win8操作系统
  • winxp系统开机启动项
  • awk 筛选有特定字符
  • win8 桌面图标
  • centos默认字体
  • pascl32.exe - pascl32是什么进程 有什么用
  • win8.1自带usb3.0驱动吗
  • win7系统迁移到另一磁盘
  • win10系统无线网络连接在哪
  • 如何实现仁
  • opengl 渲染yuv
  • Android UI之LinearLayout(线性布局)
  • python多线程例子
  • unity ngui
  • javascript中的document
  • python中os模块有什么作用
  • 使用筷子就餐会不会传染乙肝病毒
  • 安徽省电子税务局怎么下载
  • 北京车位过户手续费多少
  • 军工企业销售模式
  • 生育登记网上服务大厅山东
  • 省银保监局长是什么级别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设