以下是jQuery和JavaScript实现相同操作的等价代码。
选择元素
Javascript代码
2.var els = $('.el');
3.
4.// 原生方法
5.var els = document.querySelectorAll('.el');
6.
7.// 函数法
8.var $ = function (el) {
9. return document.querySelectorAll(el);
10.}
11.
12.var els = $('.el');
13.
14.// 或者使用regex-based micro-selector库,地址:http://jsperf.com/micro-selector-libraries
// jQuery
var els = $('.el');
// 原生方法
var els = document.querySelectorAll('.el');
// 函数法
var $ = function (el) {
return document.querySelectorAll(el);
}
var els = $('.el');
// 或者使用regex-based micro-selector库,地址:http://jsperf.com/micro-selector-libraries
创建元素
Javascript代码
2.var newEl = $('<div/>');
3.
4.// 原生方法
5.var newEl = document.createElement('div');
// jQuery
var newEl = $('<div/>');
// 原生方法
var newEl = document.createElement('div');
添加事件监听器
Javascript代码
2.$('.el').on('event', function() {
3.
4.});
5.
6.// 原生方法
7.[].forEach.call(document.querySelectorAll('.el'), function (el) {
8. el.addEventListener('event', function() {
9.
10. }, false);
11.});
设置/获取属性
Javascript代码
2.$('.el').filter(':first').attr('key', 'value');
3.$('.el').filter(':first').attr('key');
4.
5.// 原生方法
6.document.querySelector('.el').setAttribute('key', 'value');
7.document.querySelector('.el').getAttribute('key');
添加/移除/切换类
Javascript代码
2.$('.el').addClass('class');
3.$('.el').removeClass('class');
4.$('.el').toggleClass('class');
5.
6.// 原生方法
7.document.querySelector('.el').classList.add('class');
8.document.querySelector('.el').classList.remove('class');
9.document.querySelector('.el').classList.toggle('class');
附加内容(Append)
2.$('.el').append($('<div/>'));
3.
4.// 原生方法
5.document.querySelector('.el').appendChild(document.createElement('div'));
克隆元素
2.var clonedEl = $('.el').clone();
3.
4.// 原生方法
5.var clonedEl = document.querySelector('.el').cloneNode(true);
移除元素
2.$('.el').remove();
3.
4.// 原生方法
5.remove('.el');
6.
7.function remove(el) {
8. var toRemove = document.querySelector(el);
9.
10. toRemove.parentNode.removeChild(toRemove);
11.}
获取父元素
2.$('.el').parent();
3.
4.// 原生方法
5.document.querySelector('.el').parentNode;
上一个/下一个元素
2.$('.el').prev();
3.$('.el').next();
4.
5.// 原生方法
6.document.querySelector('.el').previousElementSibling;
7.document.querySelector('.el').nextElementSibling;
XHR或AJAX
$.get('url', function (data) {
});
$.post('url', {data: data}, function (data) {
});
// 原生方法
// get
var xhr = new XMLHttpRequest();
xhr.open('GET', url);
xhr.onreadystatechange = function (data) {
}
xhr.send();
// post
var xhr = new XMLHttpRequest()
xhr.open('POST', url);
23.xhr.onreadystatechange = function (data) {
}
xhr.send({data: data});
// jQuery
$.get('url', function (data) {
});
$.post('url', {data: data}, function (data) {
});
// 原生方法
// get
var xhr = new XMLHttpRequest();
xhr.open('GET', url);
xhr.onreadystatechange = function (data) {
}
xhr.send();
// post
var xhr = new XMLHttpRequest()
xhr.open('POST', url);
xhr.onreadystatechange = function (data) {
}
xhr.send({data: data});
以下是jQuery和JavaScript实现相同操作的等价代码。的更多相关文章
- jQuery? 回归JavaScript原生API
如今技术日新月异,各类框架库也是层次不穷.即便当年漫山红遍的JQuery(让开发者write less, do more,So Perfect!!)如今也有被替代的大势.但JS原生API写法依旧:并且 ...
- jQuery 选择器 筛选器 样式操作 文本操作 属性操作 文档处理 事件 动画效果 插件 each、data、Ajax
jQuery jQuery介绍 1.jQuery是一个轻量级的.兼容多浏览器的JavaScript库. 2.jQuery使用户能够更方便地处理HTML Document.Events.实现动画效果.方 ...
- JavaScript jQuery 中定义数组与操作及jquery数组操作
首先给大家介绍javascript jquery中定义数组与操作的相关知识,具体内容如下所示: 1.认识数组 数组就是某类数据的集合,数据类型可以是整型.字符串.甚至是对象Javascript不支持多 ...
- JavaScript jQuery 中定义数组与操作及jquery数组操作 http://www.jb51.net/article/76601.htm
首先给大家介绍javascript jquery中定义数组与操作的相关知识,具体内容如下所示: 1.认识数组 数组就是某类数据的集合,数据类型可以是整型.字符串.甚至是对象Javascript不支持多 ...
- JavaScript&&jQuery创建新节点和操作属性对比
JavaScript创建新节点和操作属性 通过JavaScript原生接口创建节点,在处理上是非常复杂与繁琐的. <!DOCTYPE html> <html lang="e ...
- 深入学习jQuery元素尺寸和位置操作
× 目录 [1]尺寸设置 [2]位置设置 前面的话 对于javascript来说,元素尺寸有scroll.offset.client三大属性,以及一个强大的getBoundingClientRect( ...
- jquery css事件编程 位置 操作
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- JQuery 对 Select option 的操作---转载
<select id="selectID" > <option value="1">1</option> <optio ...
- 节点的创建--对比jQuery与JavaScript 方法
一. 创建节点: 节点是DOM结构的基础,根据DOM规范,节点是一个很宽泛的概念,包含元素.属性.文本.文档和注释.但在实际开发中,要动态创建内容,主要操作的节点包括元素.属性和文本. 1.需求:创 ...
随机推荐
- 清橙A1484
http://www.tsinsen.com/ViewGProblem.page?gpid=A1484### 题解: 在线插入并不好做,我们将所有操作离线,变为删除操作. 每次询问的时候对于当前B串所 ...
- 让乔布斯立足肩上的C语言之父
2011年,人们对乔布斯的去世记忆深刻,但这一年还有另一位本应获得同样关注的人物也与世长辞,他就是C语言之父丹尼斯·里奇(Dennis Ritchie). 不过,并非所有人都没能正确认识到里奇所曾作出 ...
- Java中new关键字和newInstance方法的区别
在初始化一个类,生成一个实例的时候,newInstance()方法和new关键字除了一个是方法一个是关键字外,最主要的区别是创建对象的方式不同.newInstance()使用类加载机制,new是创建一 ...
- BZOJ 3065 带插入区间K小值
http://www.lydsy.com/JudgeOnline/problem.php?id=3065 思路:替罪羊树套权值线段树. 当替罪羊树某个子树大于某个比利(比例)时就暴力重构,本题时间复杂 ...
- VC的UNICODE 编程
简介 如果你编写的程序是针对非英语国家的用户,如中国.日本.东欧和中东地区,那么你一定要熟悉 UNICODE 字符集.尤其是用 Visual C++/MFC 编写针对上述国家和地区的用户的程序时,如果 ...
- 第一个Windows程序
今天,我们的任务就是和大家一起开发第一个Windows程序,这个程序的功能非常简单,就是弹出一个对话框,但是简单的程序可以帮助大家建立信心. 例1 第一个Windows程序 /* ********** ...
- 设计模式(五):PROTOTYPE原型模式 -- 创建型模式
1.定义 用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象. 2.适用场景 原型模式的主要思想是基于现有的对象克隆一个新的对象出来,一般是有对象的内部提供克隆的方法,通过该方法返回一个对 ...
- 解决Chrome无法加载Shockwave Flash
Shockwave Flash 是 Adobe Flash Player下的一个小插件,你可以在Google商店中找到并下载. 通常来讲,Shckwave Flash会在安装Flash Player的 ...
- R学习日记——分解时间序列(季节性数据)
上篇说明了分解非季节性数据的方法.就是通过TTS包的SMA()函数进行简单移动平均平滑.让看似没有规律或没有趋势的曲线变的有规律或趋势.然后再进行时间序列曲线的回归预测. 本次,开始分解季节性时间序列 ...
- C#获取字符串生成图片后的长度
1. 使用g.MeasureString()获得 使用MeasureString测量出来的字符宽度,总是比实际宽度大一些,而且随着字符的长度增大,貌似实际宽度和测量宽度的差距也越来越大了.查了一 ...