原生js仿jquery一些常用方法(必看篇)

最近迷上了原生js,能不用jquery等框架的情况都会手写一些js方法,记得刚接触前端的时候为了选择器而使用jquery。。。现在利用扩展原型的方法实现一些jquery函数:

1.显示/隐藏

//hide()
Object.prototype.hide = function(){
 this.style.display="none";
 return this;
}
//show()
Object.prototype.show = function(){
 this.style.display="block";
 return this;
} 

return this的好处在于链式调用。

2.滑动 省略speed和callback的传入,因为要加一串判断和处理回调,代码量大

//slideDown()
Object.prototype.slideDown = function(){
 this.style.display = 'block';
 if(this.clientHeight<this.scrollHeight){
  this.style.height=10+this.clientHeight+"px";
  var _this = this;
  setTimeout(function(){_this.slideDown()},10)
 }else{
  this.style.height=this.scrollHeight+"px";
 }
}
//slideUp()
Object.prototype.slideUp = function(){
 if(this.clientHeight>0){
  this.style.height=this.clientHeight-10+"px";
  var _this = this;
  setTimeout(function(){_this.slideUp()},10)
 }else{
  this.style.height=0;
  this.style.display = 'none';
 }
} 

3.捕获/设置

//attr()
Object.prototype.attr = function(){
 if(arguments.length==1){
  return eval("this."+arguments[0]);
 }else if(arguments.length==2){
  eval("this."+arguments[0]+"="+arguments[1]);
  return this;
 }
}
//val()
Object.prototype.val = function(){
 if(arguments.length==0){
  return this.value;
 }else if(arguments.length==1){
  this.value = arguments[0];
  return this;
 }
}
//html()
Object.prototype.html = function(){
 if(arguments.length==0){
  return this.innerHTML;
 }else if(arguments.length==1){
  this.innerHTML = arguments[0];
  return this;
 }
}
//text()需要在html()结果基础上排除标签,会很长,省略 

4.CSS方法

//css()
Object.prototype.css = function(){
 if(arguments.length==1){
  return eval("this.style."+arguments[0]);
 }else if(arguments.length==2){
  eval("this.style."+arguments[0]+"='"+arguments[1]+"'");
  return this;
 }
} 

 5.添加元素

//append()
Object.prototype.append = function(newElem){
 this.innerHTML += newElem;
 return this;
}
//prepend()
Object.prototype.prepend = function(newElem){
 this.innerHTML = arguments[0] + this.innerHTML;
 return this;
}
//after()
Object.prototype.after = function(newElem){
 this.outerHTML += arguments[0];
 return this;
}
//before()
Object.prototype.before = function(newElem){
 this.outerHTML = arguments[0] + this.outerHTML;
 return this;
} 

6.删除/替换元素

//empty()
Object.prototype.empty = function(){
 this.innerHTML = "";
 return this;
}
//replaceWith()
Object.prototype.replaceWith = function(newElem){
 this.outerHTML = arguments[0];
 return this;
}
//remove() js自带,省略。 

7.设置css类

//hasClass()
Object.prototype.hasClass = function(cName){
 return !!this.className.match( new RegExp( "(\\s|^)" + cName + "(\\s|$)") );
}
//addClass()
Object.prototype.addClass = function(cName){
 if( !this.hasClass( cName ) ){
  this.className += " " + cName;
 }
 return this;
}
//removeClass()
Object.prototype.removeClass = function(cName){
 if( this.hasClass( cName ) ){
  this.className = this.className.replace( new RegExp( "(\\s|^)" + cName + "(\\s|$)" )," " );
 }
 return this;
} 

上面的设置CSS类也可以利用html5新API classList及contains实现 但不兼容IE8以下及部分火狐浏览器

Object.prototype.hasClass = function(cName){
 return this.classList.contains(cName)
}
Object.prototype.addClass = function(cName){
 if( !this.hasClass( cName ) ){
  this.classList.add(cName);
 }
 return this;
}
Object.prototype.removeClass = function(cName){
 if( this.hasClass( cName ) ){
  this.classList.remove(cName);
 }
 return this;
} 

9.选择器

//id或class选择器$("elem")
function $(strExpr){
 var idExpr = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/;
 var classExpr = /^(?:\s*(<[\w\W]+>)[^>]*|.([\w-]*))$/;
 if(idExpr.test(strExpr)){
  var idMatch = idExpr.exec(strExpr);
  return document.getElementById(idMatch[2]);
 }else if(classExpr.test(strExpr)){
  var classMatch = classExpr.exec(strExpr);
  var allElement = document.getElementsByTagName("*");
  var ClassMatch = [];
  for(var i=0,l=allElement.length; i<l; i++){
   if(allElement[i].className.match( new RegExp( "(\\s|^)" + classMatch[2] + "(\\s|$)") )){
    ClassMatch.push(allElement[i]);
   }
  }
  return ClassMatch;
 }
} 

需要强调的是,选择器返回的结果或结果集包含的是htmlDOM,并非jquery的对象。大多数人都知道,document.getElementById("id")等价于jquery$("#id")[0],另外上面class选择器选择的结果如需使用,需要利用forEach遍历:

$(".cls").forEach(function(e){
 e.css("background","#f6f6f6")
}) 

10.遍历 siblings()和children()获取的结果也需要结合forEach使用

//siblings()
Object.prototype.siblings = function(){
 var chid=this.parentNode.children;
 var eleMatch = [];
 for(var i=0,l=chid.length;i<l;i++){
  if(chid[i]!=this){
   eleMatch.push(chid[i]);
  }
 }
 return eleMatch;
}
//children() 原生js已含有该方法,故命名为userChildren。
Object.prototype.userChildren = function(){
 var chid=this.childNodes;
 var eleMatch = [];
 for(var i=0,l=chid.length;i<l;i++){
  eleMatch.push(chid[i]);
 }
 return eleMatch;
}
//parent()
Object.prototype.parent = function(){
 return this.parentNode;
}
//next()
Object.prototype.next = function(){
 return this.nextElementSibling;
}
//prev()
Object.prototype.prev = function(){
 return this.previousElementSibling;
} 

jquery事件函数原生js已有,另外,原生js实现jquery的一个常用函数 ajax 将会在下一篇写道。

原生js实现ajax方法

以上就是小编为大家带来的原生js仿jquery一些常用方法(必看篇)的全部内容了,希望对大家有所帮助,多多支持我们~

(0)

相关推荐

  • 原生js封装的一些jquery方法(详解)

    用js封装一些常用的jquery方法 记录一下 hasClass:判断是否有class function hasClass(ele, cls) { if (!ele || !cls) return false; if (ele.classList) { return ele.classList.contains(cls); } else { return ele.className.match(new RegExp('(\\s|^)' + cls + '(\\s|$)')); } } addCl

  • 原生js仿jquery animate动画效果

    jquery animate动画效果: 代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>动画</title> <style> *{margin:0;padding:0;} .box{width: 400px;height: 300px;background: #000;margin:40

  • 详解用原生JavaScript实现jQuery的某些简单功能

    大致介绍 学习了妙味,用原生的JavaScript实现jQuery中的某些部分功能 定义自己的函数库lQuery $()选择器的实现 jQuery是面向对象的,所以自己编写的也要是面向对象的,看看基本的结构 // 定义lQuery对象 function lQuery(lArg){ } function lQ(lArg){ return new lQuery(lArg); } // css()方法 lQuery.prototype.css = function(){}; // html()方法 l

  • 使用jQuery或者原生js实现鼠标滚动加载页面新数据

    相信很多人都见过瀑布流图片布局,那些图片是动态加载出来的,效果很好,对服务器的压力相对来说也小了很多,用鼠标操作的时候相信都见过这样的效果:进入qq空间,向下拉动空间,到底部时,会动态加载剩余的说说或者是日志 ,今天我们就来看看他们的实现思路和js控制动态加载的代码. 下面的代码主要是控制滚动条下拉时的加载事件的,无论是加载图片还是加载记录数据  都可以. 加载jQuery库后我们可以这样使用: $(window).scroll(function () { var scrollTop = $(t

  • jQuery实现隔行变色的方法分析(对比原生JS)

    本文实例分析了jQuery实现隔行变色的方法.分享给大家供大家参考,具体如下: 原生js: var tab = document.getElementByTagName('table')[0]; var tr = tab.getElementByTagName('tr'); for(var i=0;i<tr.length;i++){ if(i%2==0){ tr[i].style.background="orange"; }else{ tr[i].style.background

  • 原生js和jquery分别实现横向导航菜单效果

    本文实例为大家分享了原生js和jquery横向导航菜单的制作方法,供大家参考,具体内容如下 原生javascript实现: 这一次要实现的是鼠标放上去以后,菜单栏被选中的那一栏水平拉伸,鼠标离开后水平收缩.并带有一定的时间性,使肉眼能够看出其拉伸收缩的动画效果. 开始用javascript进行编写: 首先在之前水平方向的导航栏上进行操作,将第一栏和选中栏的样式只改变为背景变黑色,文字变白色 .on,a:hover{background:#000000;color:#FFFFFF;} 之后开始写j

  • 原生js与jQuery实现简单的tab切换特效对比

    tab页签通常适用于空间有限而内容较多同时兼顾页面美观度不给用户一种信息过量视觉疲劳的情形.使用面非常广,下面我们用两种方法简单实现之. 首先,构建页面元素.页签的可点击部分我们通常用列表来承载,包括ul和ol,我们这里让页签呈横向分布,所以需要使之向左浮动.而页签内容部分使用div承载即可.另外,我们需要对具有共性的元素统一控制样式和行为,所以就有了下面的dom结构: <div id="main"> <ul id="tabbar" class=&

  • 原生js实现jquery函数animate()动画效果的简单实例

    通过在公司一个月的实习,慢慢的对css跟html算是比较熟悉了,这几天开始研究js,今天用js写了一个jquery的animate函数,测试了下,性能还可以.个人觉得jquery并不是万能的,因为是个框架,所以有些东西写的比较死,就像animate函数一样,可选的参数不多有时候可能并不能实现我们想要的效果. 注释的部分是用来测试用的,写代码的过程并不是十分顺利,因为用js平时用的不是很细,都是大体知道方法,也用过,但等到真正要实现动画函数的时候,细枝末节写错了就可能把人难住了. 函数里面有几个参

  • 原生JS和jQuery版实现文件上传功能

    本文实例分享了原生JS版和jQuery 版实现文件上传功能的例子,供大家参考,具体内容如下 <!doctype html> <html lang="zh"> <head> <meta charset="utf-8"> <title>HTML5 Ajax Uploader</title> <script src="jquery-2.1.1.min.js"></

  • 原生js和jQuery实现淡入淡出轮播效果

    本文实例为大家介绍了基于jQuery实现淡入淡出轮播效果的关键代码,分享给大家供大家参考,具体内容如下: 基本原理:将所有图片绝对定位在同一位置,透明度设为0,然后通过jQuery的淡入淡出实现图片的切换效果. html代码: <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>一个轮播&l

  • 原生JS取代一些JQuery方法的简单实现

    1.选取元素 // jQuery var els = $('.el'); // Native var els = document.querySelectorAll('.el'); // Shorthand var $ = function (el) { return document.querySelectorAll(el); } querySelectorAll方法返回的是NodeList对象,需要转换为数组. myList = Array.prototype.slice.call(myNo

  • 原生js仿jquery实现对Ajax的封装

    前言 与js相比,jquery为我们省去了冗长的获取元素的代码,不用考虑一些麻烦的兼容问题,更加方便的动画实现,以及更加方便的方法调用让我们觉得jquery真是越用越舒服.但是jquery说到底还是对js的封装,我们不光要用的舒服还要深入理解其中的原理,这样才能更好的使用它. 首先我们封装的函数为了能实现可传入无限多个参数,在使用我们即将封装的函数时,需要使用对象进行传参,形式如下: //data作为参数传入我们下面封装的函数 var data = { //数据 user:"yonghu1&qu

随机推荐