网站首页 > 教程分享 正文
前言:今天不撸代码了,说说曾经火得不行的jquery。
Jquery的辉煌时刻
在移动端页面兴起之前,可以说,传统web开发。jquery是绝对的霸主,做为web开发你说不会jquery,你都不好意思给别人打招呼。相信大多数前端er和我一样,项目中不引入jquery,我们都不知道该怎么开始下手。反正当年我直接就是引入然后
$(function(){
.....});
Jquery的优势
- 简单
- 易上手
- 优化了大量的dom操作的复杂度
- 强大的dom选择器(当然选择器这一块是依赖sizzle)
- 对各大浏览器和差异进行很友好的兼容处理
- 成千上万的插件系统。
- 链式操作
jquery之美
面向对象。给开发者提供了友好的扩展功能。
jquery用户
第一种就是只会用,直接一上来就是$(funciton(){}),绑定一堆的事件。用animate做一些动画,发一些请求,然后用是用别人的插件,实现一些轮播图什么的。不懂原理,只停留在会用的层面上,没有再深入。这时候会掉入一个坑,就是明明我们用插件实现了效果,boss很满意,第二天,boss说这个效果要修改一下,完了,一脸蒙蔽。咋办,插件没有这个配置,可能又去找别的插件。。如此循环。
于是我们只会用别人造的轮子,我们很少去想实现一个类似的轮子。所以我们不懂jquery的原理,面向对象的思想,jquery插件的是如何扩展出来。
第二种就是会用,而且基本上懂明白了Jquery的思想,读过jquery源码,于是他们知道jquery是基于面向对象的开发的。Jquery其伟大的插件机制,其原理就是在类的原型上扩展自己的方法。搞明白了插件的原理,那么我们在用别人成熟的框架的时候,如果boss要改效果,我们完全有能力自己去改别人的插件的代码的。
下面总结下我读jquery源码的收获:
- jquery基于面向对象。
- jquery扩展插件其实就是在Jquery类的原型链上增加我们自己的逻辑。
- 我们用能$.fn.methodName = function(){} 扩展,其实内部有一句$.fn = Jquery.prototype;
- 其链式调用原理都是在方法的最后加了一个return this来实现的。
Jquery不足
尽管Jquery能给我们在操作dom这一块带来极大的方便,但是,随着移动端的兴起,vue,react,angular框架的流行,虚拟dom的出现,jquery操作dom这一块的优势不再,性能方面还是有很大的问题。体积也相对较大。
写在最后
不知从什么时候开始,我把jquery从项目中移除了,并不是jquery不够好,而是我们得紧跟着web的大趋势。项目中已经有了更好的替代方案。于是我们可能真的不需要jquery了。但是Jquery依然是一个伟大的框架,曾经一代开发者的利器。
谨以此文向jquery致敬。
猜你喜欢
- 2024-10-17 jQuery基础教程学习笔记(九)常用工具函数(最后一节)
- 2024-10-17 【老兵不朽】时隔1年、jQuery再发新版
- 2024-10-17 用原生 JavaScript 实现十大 jQuery 函数
- 2024-10-17 如何批量删除新浪微博内容?(新浪微博app怎么批量删除微博)
- 2024-10-17 jQuery 遍历- 过滤(jquery遍历li)
- 2024-10-17 4、JQuery 的常用的方法增、删、复制、改、查(必会)
- 2024-10-17 竟然还在更新?jQuery 3.6.1 更新发布
- 2024-10-17 重走JAVA编程路,DOM操作的强大封装类库:Jquery
- 2024-10-17 jQuery事件的解绑和触发(jquery中绑定和解绑的事件有哪些)
- 2024-10-17 前端讨论 - 你是否还需要jQuery(党支部委员会讨论是否确定为发展对象的意见)
你 发表评论:
欢迎- 最近发表
-
- 有了这份900多页的Android面试指南,你离大厂Offer还远吗?
- K2 Blackpearl 流程平台总体功能介绍:常规流程功能
- 零基础安卓开发起步(一)(安卓开发入门视频)
- 教程:让你的安卓像Windows一样实现程序窗口化运行
- Android事件总线还能怎么玩?(事件总线有什么好处)
- Android 面试被问“谈谈架构”,到底要怎样回答才好?
- Android开发工具Parcel和Serialize
- Android 中Notification的运用(notification widget安卓)
- Android退出所有Activity最优雅的方式
- MT管理器-简单实战-去除启动页(mt管理器怎么去除软件弹窗)
- 标签列表
-
- css导航条 (66)
- sqlinsert (63)
- js提交表单 (60)
- param (62)
- parentelement (65)
- jquery分享 (62)
- check约束 (64)
- curl_init (68)
- sql if语句 (69)
- import (66)
- chmod文件夹 (71)
- clearinterval (71)
- pythonrange (62)
- 数组长度 (61)
- javafx (59)
- 全局消息钩子 (64)
- sort排序 (62)
- jdbc (69)
- php网页源码 (59)
- assert h (69)
- httpclientjar (60)
- postgresql conf (59)
- winform开发 (59)
- mysql数字类型 (71)
- drawimage (61)
本文暂时没有评论,来添加一个吧(●'◡'●)