jQuery的原生替代
jQuery的原生替代,参考自你不需要jQuery,对其进行了更清晰的总结与分类,现代游览器基本都支持(ie10+以上),只整理了最简洁实用的原生代码,过分累赘的实现没有加入
元素获取
| jQuery | 原生 |
|---|---|
| $(selector) | document.querySelectorAll(selector) |
| $(el).find(selector) | el.querySelectorAll(selector) |
| $(el).prev() | el.previousElementSibling |
| $(el).next() | el.nextElementSibling |
| $(el).first() | el.firstElementChild |
| $(el).last() | el.lastElementChild |
| $(el).parent() | el.parentNode |
| $(el).offsetParent() | el.offsetParent |
| $(el).children() | el.children |
| $(el).siblings() | Array.prototype.filter.call(el.parentNode.children, child => child !== el) |
dom操作
| jQuery | 原生 |
|---|---|
| $(el).before(htmlString) | el.insertAdjacentHTML('beforebegin', htmlString) => el.before(string) |
| $(el).after(htmlString) | el.insertAdjacentHTML('afterend', htmlString) => el.after(string) |
| $(parent).prepend(el) | parent.insertBefore(el, parent.firstChild) => el.prepend(htmlString) |
| $(parent).append(el) | parent.appendChild(el) => el.append(htmlString) |
| $(el).remove() | el.parentNode.removeChild(el) => el.remove() |
| $(el).clone() | el.cloneNode(true) |
| $(el).empty() | el.innerHTML = '' |
| $(el).replaceWith(string) | el.outerHTML = string |
| $(el).html(string) | el.innerHTML = string |
| $(el).text(string) | el.textContent = string |
| $(el).val(string) | el.value = string |
| $(el).html() | el.innerHTML |
| $(el).text() | el.textContent |
| $(el).val() | el.value |
样式操作
| jQuery | 原生 |
|---|---|
| $(el).hasClass(className) | el.classList.contains(className) |
| $(el).addClass(className) | el.classList.add(className) |
| $(el).removeClass(className) | el.classList.remove(className) |
| $(el).toggleClass(className) | el.classList.toggle(className) |
| $(el).css(ruleName) | getComputedStyle(el)[ruleName] |
| $(el).css('width', '20px') | el.style.width = '20px' |
属性操作
| jQuery | 原生 |
|---|---|
| $(el).attr('title') | el.getAttribute('title') |
| $(el).attr('title', string) | el.setAttribute('title', string) |
位置/尺寸
| jQuery | 原生 |
|---|---|
| $(el).position() | { left: el.offsetLeft, top: el.offsetTop } |
| $(el).offset() | el.getBoundingClientRect() |
| $(el).outerWidth() | el.offsetWidth |
| $(el).outerHeight() | el.offsetHeight |
| $(el).scrollTop() | el.scrollTop |
| $(el).scrollLeft() | el.scrollLeft |
特效
| jQuery | 原生 |
|---|---|
| $(el).hide() | el.style.display = 'none' |
| $(el).show() | el.style.display = '' |
dom载入完毕
| jQuery | 原生 |
|---|---|
| $(方法) | document.addEventListener('DOMContentLoaded', 方法) |
jQuery的原生替代的更多相关文章
- jQuery与原生js实现banner轮播图
jQuery与原生js实现banner轮播图: (jq需自己加载)(图片需自己加载) <!DOCTYPE html> <html> <head> <meta ...
- 通过游戏认识 --- JQuery与原生JS的差异
前言 jQuery是一个快速.简洁的JavaScript框架,是继Prototype之后又一个优秀的JavaScript代码库( 或JavaScript框架).jQuery设计的宗旨是“write ...
- 原生JS的使用,包括jquery和原生JS获取节点、jquery和原生JS修改属性的比较
一.前言 相比于JS这条直达终点.满是荆棘的小路,jquery无疑是康庄大道了,足够的简洁.易用给了它辉煌的地位.然而,毕竟是绕着道的插件,当小路走着走着变成大路的时候,曾经的大路也就失去了他自身的优 ...
- 通过案例来剖析JQuery与原生JS
首先来个例子: 我们在登陆或者注册一些网站时,如果某一项点过了但没填,鼠标移走后是不是经常看到网站有相应的红色字体提示呢? 那下面我们就以这个为例来剖析下jQuery和原生JS的一些区别,来上代码: ...
- 抛弃jQuery 深入原生的JavaScript
虽然我已经做网站建设工作10多年了,但我从最近3年才开始更多地学习如何更好的将纯JavaScript用于工作中,而不总是将jQuery考虑在第一位.现在我每天学习很多东西.这个过程让我觉得Adtile ...
- jQuery与原生JS相互转化
前端发展很快,现代浏览器原生 API 已经足够好用.我们并不需要为了操作 DOM.Event 等再学习一下 jQuery 的 API.同时由于 React.Angular.Vue 等框架的流行,直接操 ...
- 用jQuery基于原生js封装的轮播
我发现轮播在很多网站里面都用到过,一个绚丽的轮播可以为网页增色不少,最近闲来无事,也用原生js封装了一个轮播,可能不像网上的插件那么炫,但是也有用心去做.主要用了闭包的思想.需要传递的参数有:图片地址 ...
- 【jQuery、原生】键盘键入两位小数
jquery的处理办法 <!doctype html> <html lang="en"> <head> <meta charset=&qu ...
- JQuery和原生JS跨域加载JSON数据或HTML。
前提:有时候需要在网页上,加载另一个网站上的数据.或者加载另一个网站上的一个页面.Js的Ajax请求不具备跨域功能,可以使用JQuery来实现. 网页端JS代码: $(function () { $. ...
随机推荐
- redis 获取自增数
近期,有一个项目需要用到数字的自增整数,范围是0-199999,但公司数据库是mongodb.同时装有mysql.redis等存储数据的这些数据库,其中redis是集群模式,mongodb是paa( ...
- SpringBootSecurity学习(01)网页版登录入门介绍
Web应用安全管理 Web应用的安全管理,主要包括两个方面的内容,一个是用户身份的认证,即用户登录的设计,二是用户授权,即一个用户在一个应用系统中能够执行哪些操作的权限管理.权限管理的设计一般使用角色 ...
- 从 Int 到 Integer 对象,细细品来还是有不少东西
int 是 Java 八大原始类型之一,是 Java 语言中为数不多不是对象的东西,Integer 是 int 的包装类,里面使用了一个 int 类型的变量来存储数据,提供了一些整数之间的常用操作,常 ...
- Spring MVC-从零开始-view-ViewResolver
主要ViewResolver简介 InternalResourceViewResolver 将逻辑视图名解析为一个路径 BeanNameViewResolver 将逻辑视图名解析为bean的name属 ...
- 探索ASP.NET Core 3.0系列一:新的项目文件、Program.cs和generic host
前言:在这篇文章中我们来看看ASP.Net Core 3.0应用程序中一些基本的部分—— .csproj项目文件和Program.cs文件.我将会介绍它们从 ASP.NET Core 2.x 中的默认 ...
- mysql replace into使用
使用mysql插入数据时,我们通常使用的是insert into来处理,replace into有时可以替代insert into功能,但replace into也有自己的用法 准备一张测试表: CR ...
- 认识MongoDB复制集
从这一篇开始,我们要踏上MongoDB进阶之路啦,想想还有点小开心呢.一筐猪镇楼. 引入复制集 我们先来想一个场景,如果本地项目使用MongoDB,都是下载,安装,连接一条龙服务.这实际也就是 ...
- 创建新镜像-从已创建的容器中更新镜像并提交镜像(以Nginx为例)
目标:现在我们主要是修改nginx的index.html,然后做一个新镜像 1.基于nginx:1.12运行一个容器 docker run -d -p 8080:80 --name nginx ngi ...
- 分布式系统的延时和故障容错之Spring Cloud Hystrix
本示例主要介绍 Spring Cloud 系列中的 Eureka,如何使用Hystrix熔断器容错保护我们的应用程序. 在微服务架构中,系统被拆分成很多个服务单元,各个服务单元的应用通过 HTTP 相 ...
- 我在用的翻译软件 -> 微软翻译+网易有道词典+谷歌翻译
Windows网页翻译 因为微软翻译相对来说翻译网页更为准确,我也喜欢用谷歌的Chrome浏览器,但是我没找到微软翻译的扩展,这里只能放弃 这个需要配合Microsoft Edge浏览器进行使用,也是 ...